Apache

Z wiki linux-user
Skocz do: nawigacji, wyszukiwania
(Inne polecenia dla serwera apache)
 
Linia 1: Linia 1:
 
[[Category:Serwer]]
 
[[Category:Serwer]]
 
== Apache ==  
 
== Apache ==  
== Serwer httpd apache ==
 
 
 
'''Apache''' jest oprogramowaniem służącym do realizacji zapytań protokołu http. Kod pakietu jak i sama aplikacja jest dostępna na licencji Apache License i jest w pełni darmowa.
 
'''Apache''' jest oprogramowaniem służącym do realizacji zapytań protokołu http. Kod pakietu jak i sama aplikacja jest dostępna na licencji Apache License i jest w pełni darmowa.
 
== Instalacja ==
 
== Instalacja ==
Aby zainstalować serwer apacje w wersji 2+ należy wydać polecenie
+
Aby zainstalować serwer apache 2+ najlepiej pobrać jego najnowszą stabilną wersję i wykonać samodzielną kompilację. W większości dystrybucji można wykorzystać gotowy pakiet który jest już wstępnie skonfigurowany. Przykładowo w CentOS(i innych dystrybucjach które pochodzą od RH) należy wydać polecenie
 
  yum install http*
 
  yum install http*
 
 
lub
 
lub
 
  yum groupinstall "Web Server"
 
  yum groupinstall "Web Server"
 +
w Debianie czy ubuntu wydamy polecenie
 +
apt-get install apache2
  
Aby była możliwość używania bezpiecznego protokołu ''https'', należy doinstalować moduł ''mod_ssl''
+
Aby była możliwość używania bezpiecznego protokołu ''https'', w CentOS należy doinstalować moduł ''mod_ssl''  
 
  yum install mod_ssl
 
  yum install mod_ssl
 +
w Debianie należy go tylko uaktywnić tworząc odpowiednie dowiązania symboliczne
 +
ln -s /etc/apache2/mods-available/ssl.load /etc/apache2/mods-enabled/
 +
ln -s /etc/apache2/mods-available/ssl.conf /etc/apache2/mods-enabled/
  
Po zainstalowaniu pakietów możemy włączyć serwer za pomocą kilku różnych poleceń
+
Po zainstalowaniu pakietów możemy włączyć serwer za pomocą kilku różnych poleceń w CentOS
 
  /etc/init.d/httpd start
 
  /etc/init.d/httpd start
  
Linia 20: Linia 22:
 
  apachectl start
 
  apachectl start
  
to samo dotyczy się wykonywania operacji restartu sprawdzania statusu czy zatrzymywania serwera, polecenia przedstawiam poniżej
+
natomiast w Debianie serwer wystartował po jego instalacji my musimy tylko go zrestartować
zatrzymywanie serwera
+
  /etc/init.d/apache2 restart
apachectl stop
+
podobnie wygląda restart w CentOS, polecenia przedstawione są poniżej
  /etc/init.d/httpd stop
+
service httpd stop
+
  
 
restartowanie serwera
 
restartowanie serwera
Linia 30: Linia 30:
 
  /etc/init.d/httpd restart
 
  /etc/init.d/httpd restart
 
  service httpd restart
 
  service httpd restart
 +
 +
zatrzymywanie serwera w CentOS
 +
apachectl stop
 +
/etc/init.d/httpd stop
 +
service httpd stop
 +
zatrzymanie serwra w Debianie
 +
/etc/init.d/apache2 stop
  
 
sprawdzanie statusu
 
sprawdzanie statusu
  
  apachectl status/etc/init.d/httpd status service httpd status  
+
  apachectl status
 +
/etc/init.d/httpd status  
 +
service httpd status  
  
 
Istnieje również możliwość przeładowania konfiguracji apach'a bez jego zatrzymywania, uczynimy to za pomocą polecenia
 
Istnieje również możliwość przeładowania konfiguracji apach'a bez jego zatrzymywania, uczynimy to za pomocą polecenia
 
  apachectl reload
 
  apachectl reload
 
  /etc/init.d/httpd reload
 
  /etc/init.d/httpd reload
  service httpd reload  
+
  service httpd reload
 +
 
 
== Inne polecenia dla serwera '''apache''' ==
 
== Inne polecenia dla serwera '''apache''' ==
Możliwość sprawdzenia plików konfiguracyjnych serwera
+
Możliwość sprawdzenia plików konfiguracyjnych serwera w CentOS
 
  httpd -t
 
  httpd -t
  
Linia 52: Linia 62:
 
  httpd -l
 
  httpd -l
  
Aby zobaczyć wszystkie polecenia poczytaj strone man. Możesz ją przeczytać za pomocą polecenia
+
Pamiętając że w Debianie pakiet nazywa się apache2 polecenia przyjmą postać
 +
apache2 -t
 +
 
 +
lub
 +
apache2 -S
 +
 
 +
wyświetlenie parametrów z jakimi został zainstalowany apache
 +
apache2 -V
 +
 
 +
lista zainstalowanych modułów
 +
apache2 -l
 +
Aby zobaczyć wszystkie polecenia poczytaj stronę podręcznika man dla serwera Apache. Możesz ją wyświetlić za pomocą polecenia man nazwa serwera czyli w CentOS
 
  man httpd
 
  man httpd
 +
 +
lub
 +
 +
man apache2
 +
 +
w Debianie
 +
 
== Konfiguracja serwera apache ==
 
== Konfiguracja serwera apache ==
 
Serwer '''apache''' potrafi działać w trzech trybach '''prefork''', '''worker''' oraz '''event''' używając mechanizmu, tzw MPM (''Multi-Processing Modules''). W sytemach red hatowych domyślnie działa w trybie prefork.  
 
Serwer '''apache''' potrafi działać w trzech trybach '''prefork''', '''worker''' oraz '''event''' używając mechanizmu, tzw MPM (''Multi-Processing Modules''). W sytemach red hatowych domyślnie działa w trybie prefork.  
  
* '''prefork''' domyślny tryb, najmniej awaryjny lecz zużywający najwięcej pamięci. * worker charakteryzuje się obsługą żądania za pomocą osobnych wątków procesora, jest szybszy niż prefork, jednak jest bardziej podatny na awarie, jest njawydajniejszy gdy używa się go na komputerach wieloprocesorowych. Nie powinno się go używać do serwowania stron opartych na php. * event jest trybem eksperymentalnym.  
+
* '''prefork''' domyślny tryb, najmniej awaryjny lecz zużywający najwięcej pamięci.  
 +
* '''worker''' charakteryzuje się obsługą żądania za pomocą osobnych wątków procesora, jest szybszy niż prefork, jednak jest bardziej podatny na awarie, jest njawydajniejszy gdy używa się go na komputerach wieloprocesorowych. Nie powinno się go używać do serwowania stron opartych na php.
 +
* '''event''' jest trybem eksperymentalnym.  
  
 
Aby zmienić tryb pracy serwera należy dokonać zmian w pliku ''/etc/sysconfig/httpd'' i zrestartować serwer.
 
Aby zmienić tryb pracy serwera należy dokonać zmian w pliku ''/etc/sysconfig/httpd'' i zrestartować serwer.
Linia 82: Linia 112:
 
'''Apache''' przetrzymuje wszystkie pliki konfiguracyjne w pliku ''/etc/httpd'', głównym plikiem konfiguracyjnym jest ''/etc/httpd/conf/httpd.conf''. Natomiast logi przechowywane są w katalogu ''/var/log/httpd/''.
 
'''Apache''' przetrzymuje wszystkie pliki konfiguracyjne w pliku ''/etc/httpd'', głównym plikiem konfiguracyjnym jest ''/etc/httpd/conf/httpd.conf''. Natomiast logi przechowywane są w katalogu ''/var/log/httpd/''.
  
== Opcje pliku konfiguracyjnego httpd.conf ==
+
=== Opcje pliku konfiguracyjnego httpd.conf ===
ServerTokens opcja określa jak skale szczegółowości wyświetlanych informacji jeśi pojawi się błąd . Domyślną wartości jest Min, inne wartości to OS, Prod, Major, Minor, Min, Full
+
  
ServerRoot opcja wskazuje na miejsce przechowywania plików konfiguracyjnych serwera
+
*'''ServerTokens''' opcja określa jak skale szczegółowości wyświetlanych informacji jeśi pojawi się błąd . Domyślną wartości jest Min, inne wartości to OS, Prod, Major, Minor, Min, Full
  
Timeout domyślnie 120, określa czas obsługi żądania
+
*'''ServerRoot''' opcja wskazuje na miejsce przechowywania plików konfiguracyjnych serwera
  
KeepAlive wartości on lub off opcja powoduje włączenie lub wyłączenie obsługi stałych połączeń
+
*'''Timeout''' domyślnie 120, określa czas obsługi żądania
  
MaxKeepAliveRequests limit stałych połączeń, wartość 0 określa brak limitów
+
*'''KeepAlive''' wartości on lub off opcja powoduje włączenie lub wyłączenie obsługi stałych połączeń
  
KeepAliveTimeout czas po upływie którego połączenie zostanie rozłączone, określa się w sekundach
+
*'''MaxKeepAliveRequests''' limit stałych połączeń, wartość 0 określa brak limitów
  
StartServers ilość pod procesów, które mogą obsługiwać żądania, zawsze +1
+
*'''KeepAliveTimeout''' czas po upływie którego połączenie zostanie rozłączone, określa się w sekundach
  
MinSpareServers liczba minimalna wolnych pod procesów
+
*'''StartServers''' ilość pod procesów, które mogą obsługiwać żądania, zawsze +1
  
MaxSpareServers maksymalna liczba pod procesów, zawsze musi być o jeden większe niż MinSpareServers
+
*'''MinSpareServers''' liczba minimalna wolnych pod procesów
  
ServerLimit maksymalny limit procesów serwera max 20000
+
*'''MaxSpareServers''' maksymalna liczba pod procesów, zawsze musi być o jeden większe niż MinSpareServers
  
MaxClients
+
*'''ServerLimit''' maksymalny limit procesów serwera max 20000
określenie limitu obsługi jednoczesnych żądań, jeśli jest ich więcej to pozostałe czekają na zwolnienie się miejsca
+
  
 +
*'''MaxClients''' określenie limitu obsługi jednoczesnych żądań, jeśli jest ich więcej to pozostałe czekają na zwolnienie się miejsca
  
 +
*'''MaxRequestsPerChild''' określa limit obsługi żądań przez jeden pod proces
  
MaxRequestsPerChild określa limit obsługi żądań przez jeden pod proces
+
*'''MinSpareThreads''' minimalna ilość wątków obsługujących inne żądania
  
 +
*'''MaxSpareThreads''' maksymalna ilość wątków obsługujących inne żądania
  
 +
*'''ThgreadsPerChild''' liczba wątków przypisanych do każdego pod procesu serwera
  
MinSpareThreads minimalna ilość wątków obsługujących inne żądania
+
*'''Listen''' opcja ustawia port oraz adres ip na jakim nasłuchuje serwer
  
 +
*'''LoadModules''' ładowanie dodakowych modułów
  
 +
*'''Include''' dołącza zawartość innego pliku
  
MaxSpareThreads maksymalna ilość wątków obsługujących inne żądania
+
*'''User''' określa właściciela procesów serwera
  
 +
*'''Group''' określa grupę procesów serwera
  
 +
*'''ServerAdmin''' adres email administratora strony
  
ThgreadsPerChild liczba wątków przypisanych do każdego pod procesu serwera
+
*'''ServerName''' nazwa hosta + port, nazwa sluży do szybkiego określania adresu serwera.
  
 +
*'''UseCanonicalName''' włącz/wyłącz on/off, definiuje, w jaki sposób httpd obsługuje URL. Gdy opcja ustawiona na on, używana jest nazwa z ServerName. Jeżeli opcja jest ustawiona na off, używana jest nazwa pochodząca z zapytania klienta.
  
 +
*'''DocumentRoot''' ścieżka do katalogu z plikami strony www
  
Listen opcja ustawia port oraz adres ip na jakim nasłuchuje serwer
+
*'''Options''' dodatkowe opcje udostępnionej strony
  
 +
*'''AllowOverride''' umożliwia użycie pliku .htaccess
  
 +
*'''Order''' ustawia kolejność rozpatrywania poleceń Allow oraz Deny
  
LoadModules ładowanie dodakowych modułów
+
*'''Allow''' hosty, które mają dostęp do zasobów
  
 +
*'''Deny''' hosty, które nie mają dostępu do zasobów
  
 +
*'''UserDir''' ścieżka do katalogów stron www użytkowników systemu
  
Include dołącza zawartość innego pliku
+
*'''DirectoryIndex''' określa główną strone serwera, która jako pierwsza będzie się wyświetlać
  
 +
*'''AccessFileName''' domyślnie plik .htaccess, który zawiera uprawnienia dla żądanego katalogu
  
User określa właściciela procesów serwera
+
*'''DefaultType''' określa domyślne typy plików
  
 +
*'''MIMEMagicFile''' określanie typu pliku na podstawie jego zawartości
  
 +
*'''HostNameLookups''' rozwiązywanie nazw hostów na adresy ip
  
Group określa grupę procesów serwera
+
*'''ErrorLog''' ścieżka do plików z błędami
  
 +
*'''LogLevel''' ustawia szczegółowość zbieranych informacji
  
 +
*'''LogFormat''' opcja pozwalająca określenie jakie informacje mają się zbierać w logach
  
ServerAdmin adres email administratora strony
+
*'''CustomLog''' opcja odpowiedzialna za stworzenie pliku z logiem w odpowiednim formacie
  
 +
*'''ServerSignature''' ustawia podpis serwera na stronach błędów
  
 +
*'''Alias''' określa ścieżkę katalogu
  
ServerName nazwa hosta + port, nazwa sluży do szybkiego określania adresu serwera.
+
*'''IndexOptions''' opcja umożliwia okeślenie typów plików jakie są listowane dla DirectoryIndex
  
 +
*'''AddIconByEncoding''' przypisuje ikony plikom na podstawie ich kodowania MIME
  
 +
*'''AddIconByType''' przypisuje ikony na podstawie ich typu
  
UseCanonicalName włącz/wyłącz on/off, definiuje, w jaki sposób httpd obsługuje URL. Gdy opcja ustawiona na on, używana jest nazwa z ServerName. Jeżeli opcja jest ustawiona na off, używana jest nazwa pochodząca z zapytania klienta.
+
*'''AddIcon''' przpisuje ikony na podstawie ich rozszerzenia
  
 +
*'''DefaultIcon''' określa domyślną ikonę dla nierozpoznanych ikon
  
 +
*'''HeaderName''' ścieżka do pliku HEADER
  
DocumentRoot ścieżka do katalogu z plikami strony www
+
*'''IndexIgnore''' określa które pliki mają być ignorowane przy generowaniuindeksu strony
  
 +
*'''AddLanguage''' rozszerzeia dla plików językowych
  
 +
*'''LanguagePriority''' określa domyślne języki jeśli żadne nie zostały wybrane
  
Options dodatkowe opcje udostępnionej strony
+
*'''AddDefaultCharset''' kodowanie plików strony
  
 +
*'''AddType''' zmienia pliki o danym rozszerzeniu do typu MIME
  
 +
*'''AddOutputFilter''' umożliwia plików o danym rozszerzeniu do określonego filtra
  
AllowOverride umożliwia użycie pliku .htaccess
+
*'''BrowserMatch''' umożliwia sprecyzowanie odpowiedzi dla różnych przeglądarek
  
 +
=== Opcje dla serwerów virtualnych ===
 +
*'''NameVirtualHost''' określenie adresów ip dla virtualnych hostów
  
 +
*'''ServerAdmin''' ustawia adres email dla zdefiniowanego virtualnego serwera
  
Order ustawia kolejność rozpatrywania poleceń Allow oraz Deny
+
*'''DocumentRoot''' ustawia główny katalog gdzie będą przechowywane pliki stron www dla danego hosta
  
 +
*'''ServerName''' ścieżka url dla wirtualnego hosta
  
 +
*'''ErrorLog''' określa ścieżkę do pliku z logami błędów dla wirtualnego hosta
  
Allow hosty, które mają dostęp do zasobów
+
*'''CustomLog''' ścieżka do dodatkowych plików z logami
  
 +
== Statystyki serwera ==
  
 +
Aby odblokować statystyki serwera (server-info oraz server-status) należy odhaszować:
 +
SetHandler server-info
 +
Order deny,allow
 +
Deny from all
 +
Allow from .example.com
 +
Allow from 127.0.0.0/8
  
Deny hosty, które nie mają dostępu do zasobów
+
lub
 +
MSetHandler server-status
 +
Order deny,allow
 +
Deny from all
 +
Allow from .example.com
 +
Allow from 127.0.0.1/8
  
 +
== Prywatne strony użytkowników ==
  
 
+
Aby włączyć prywatne strony użytkowników należy odpowiednio skonfigurować poniższe linijki głównego pliku konfiguracyjnego UserDir /home/*/public_html
UserDir ścieżka do katalogów stron www użytkowników systemu
+
#
 
+
# Control access to UserDir directories. The following is an example
 
+
# for a site where these directories are restricted to read-only.
 
+
#
UserDir ścieżka do katalogów stron www użytkowników systemu
+
AllowOverride FileInfo AuthConfig LimitOptions MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec
 
+
Order allow,deny
 
+
Allow from all
 
+
Order deny,allow
DirectoryIndex określa główną strone serwera, która jako pierwsza będzie się wyświetlać
+
Deny from all
 
+
 
+
 
+
AccessFileName domyślnie plik .htaccess, który zawiera uprawnienia dla żądanego katalogu
+
 
+
 
+
 
+
DefaultType określa domyślne typy plików
+
 
+
 
+
 
+
MIMEMagicFile określanie typu pliku na podstawie jego zawartości
+
 
+
 
+
 
+
HostNameLookups rozwiązywanie nazw hostów na adresy ip
+
 
+
 
+
 
+
ErrorLog ścieżka do plików z błędami
+
 
+
 
+
 
+
LogLevel ustawia szczegółowość zbieranych informacji
+
 
+
 
+
 
+
LogFormat opcja pozwalająca określenie jakie informacje mają się zbierać w logach
+
 
+
 
+
 
+
CustomLog opcja odpowiedzialna za stworzenie pliku z logiem w odpowiednim formacie
+
 
+
 
+
 
+
ServerSignature ustawia podpis serwera na stronach błędów
+
 
+
 
+
 
+
Alias określa ścieżkę katalogu
+
 
+
 
+
 
+
IndexOptions opcja umożliwia okeślenie typów plików jakie są listowane dla DirectoryIndex
+
 
+
 
+
 
+
AddIconByEncoding przypisuje ikony plikom na podstawie ich kodowania MIME
+
 
+
 
+
 
+
AddIconByType przypisuje ikony na podstawie ich typu
+
 
+
 
+
 
+
AddIcon przpisuje ikony na podstawie ich rozszerzenia
+
 
+
 
+
 
+
DefaultIcon określa domyślną ikonę dla nierozpoznanych ikon
+
 
+
 
+
 
+
HeaderName ścieżka do pliku HEADER
+
 
+
 
+
 
+
IndexIgnore określa które pliki mają być ignorowane przy generowaniuindeksu strony
+
 
+
 
+
 
+
AddLanguage rozszerzeia dla plików językowych
+
 
+
 
+
 
+
LanguagePriority określa domyślne języki jeśli żadne nie zostały wybrane
+
 
+
 
+
 
+
AddDefaultCharset kodowanie plików strony
+
 
+
 
+
 
+
AddType zmienia pliki o danym rozszerzeniu do typu MIME
+
 
+
 
+
 
+
AddOutputFilter umożliwia plików o danym rozszerzeniu do określonego filtra
+
 
+
  
  
BrowserMatch umożliwia sprecyzowanie odpowiedzi dla różnych przeglądarek
+
Należy określić odpowiednie ścieżki do katalogów, zadbać o to aby te katalogi istniały i miały odpowiednie prawa dostępu(użytkownik prawo do wszystkiego, reszta przynajmniej do czytania). Takie strony będą widoczne w adresie http://twoje_ip/~user<br />
 +
<br /><google1 style="4"></google1>

Aktualna wersja na dzień 07:53, 6 lip 2012

Osobiste
Przestrzenie nazw

Warianty
Działania
Nawigacja
Narzędzia


Sponsor serwisu

Firma informatyczna ITProjek Bydgoszcz usługi informacztyczne, serwery, linux, windows, strony www, hosting, sieci komputerowe, system archiwizacji danych