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
+
*'''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
+
*'''ServerRoot''' opcja wskazuje na miejsce przechowywania plików konfiguracyjnych serwera
  
*Timeout domyślnie 120, określa czas obsługi żądania
+
*'''Timeout''' domyślnie 120, określa czas obsługi żądania
  
*KeepAlive wartości on lub off opcja powoduje włączenie lub wyłączenie obsługi stałych połączeń
+
*'''KeepAlive''' wartości on lub off opcja powoduje włączenie lub wyłączenie obsługi stałych połączeń
  
MaxKeepAliveRequests limit stałych połączeń, wartość 0 określa brak limitów
+
*'''MaxKeepAliveRequests''' limit stałych połączeń, wartość 0 określa brak limitów
  
KeepAliveTimeout czas po upływie którego połączenie zostanie rozłączone, określa się w sekundach
+
*'''KeepAliveTimeout''' czas po upływie którego połączenie zostanie rozłączone, określa się w sekundach
  
StartServers ilość pod procesów, które mogą obsługiwać żądania, zawsze +1
+
*'''StartServers''' ilość pod procesów, które mogą obsługiwać żądania, zawsze +1
  
MinSpareServers liczba minimalna wolnych pod procesów
+
*'''MinSpareServers''' liczba minimalna wolnych pod procesów
  
MaxSpareServers maksymalna liczba pod procesów, zawsze musi być o jeden większe niż MinSpareServers
+
*'''MaxSpareServers''' maksymalna liczba pod procesów, zawsze musi być o jeden większe niż MinSpareServers
  
ServerLimit maksymalny limit procesów serwera max 20000
+
*'''ServerLimit''' maksymalny limit procesów serwera max 20000
  
MaxClients
+
*'''MaxClients''' określenie limitu obsługi jednoczesnych żądań, jeśli jest ich więcej to pozostałe czekają na zwolnienie się miejsca
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
  
 +
*'''MinSpareThreads''' minimalna ilość wątków obsługujących inne żądania
  
MaxRequestsPerChild określa limit obsługi żądań przez jeden pod proces
+
*'''MaxSpareThreads''' maksymalna ilość wątków obsługujących inne żądania
  
 +
*'''ThgreadsPerChild''' liczba wątków przypisanych do każdego pod procesu serwera
  
 +
*'''Listen''' opcja ustawia port oraz adres ip na jakim nasłuchuje serwer
  
MinSpareThreads minimalna ilość wątków obsługujących inne żądania
+
*'''LoadModules''' ładowanie dodakowych modułów
  
 +
*'''Include''' dołącza zawartość innego pliku
  
 +
*'''User''' określa właściciela procesów serwera
  
MaxSpareThreads maksymalna ilość wątków obsługujących inne żądania
+
*'''Group''' określa grupę procesów serwera
  
 +
*'''ServerAdmin''' adres email administratora strony
  
 +
*'''ServerName''' nazwa hosta + port, nazwa sluży do szybkiego określania adresu serwera.
  
ThgreadsPerChild liczba wątków przypisanych do każdego pod procesu 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
  
 +
*'''Options''' dodatkowe opcje udostępnionej strony
  
Listen opcja ustawia port oraz adres ip na jakim nasłuchuje serwer
+
*'''AllowOverride''' umożliwia użycie pliku .htaccess
  
 +
*'''Order''' ustawia kolejność rozpatrywania poleceń Allow oraz Deny
  
 +
*'''Allow''' hosty, które mają dostęp do zasobów
  
LoadModules ładowanie dodakowych modułów
+
*'''Deny''' hosty, które nie mają dostępu do zasobów
  
 +
*'''UserDir''' ścieżka do katalogów stron www użytkowników systemu
  
 +
*'''DirectoryIndex''' określa główną strone serwera, która jako pierwsza będzie się wyświetlać
  
Include dołącza zawartość innego pliku
+
*'''AccessFileName''' domyślnie plik .htaccess, który zawiera uprawnienia dla żądanego katalogu
  
 +
*'''DefaultType''' określa domyślne typy plików
  
User określa właściciela procesów serwera
+
*'''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
  
Group określa grupę procesów serwera
+
*'''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
  
ServerAdmin adres email administratora strony
+
*'''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
  
ServerName nazwa hosta + port, nazwa sluży do szybkiego określania adresu serwera.
+
*'''AddIconByEncoding''' przypisuje ikony plikom na podstawie ich kodowania MIME
  
 +
*'''AddIconByType''' przypisuje ikony na podstawie ich typu
  
 +
*'''AddIcon''' przpisuje ikony na podstawie ich rozszerzenia
  
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.
+
*'''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
  
DocumentRoot ścieżka do katalogu z plikami strony www
+
*'''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
  
Options dodatkowe opcje udostępnionej 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
  
AllowOverride umożliwia użycie pliku .htaccess
+
=== Opcje dla serwerów virtualnych ===
 +
*'''NameVirtualHost''' określenie adresów ip dla virtualnych hostów
  
 +
*'''ServerAdmin''' ustawia adres email dla zdefiniowanego virtualnego serwera
  
 +
*'''DocumentRoot''' ustawia główny katalog gdzie będą przechowywane pliki stron www dla danego hosta
  
Order ustawia kolejność rozpatrywania poleceń Allow oraz Deny
+
*'''ServerName''' ścieżka url dla wirtualnego hosta
  
 +
*'''ErrorLog''' określa ścieżkę do pliku z logami błędów dla wirtualnego hosta
  
 +
*'''CustomLog''' ścieżka do dodatkowych plików z logami
  
Allow hosty, które mają dostęp do zasobów
+
== 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
  
 +
lub
 +
MSetHandler server-status
 +
Order deny,allow
 +
Deny from all
 +
Allow from .example.com
 +
Allow from 127.0.0.1/8
  
Deny hosty, które nie mają dostępu do zasobów
+
== Prywatne strony użytkowników ==
 
+
 
+
 
+
UserDir ścieżka do katalogów stron www użytkowników systemu
+
 
+
 
+
 
+
UserDir ścieżka do katalogów stron www użytkowników systemu
+
 
+
 
+
 
+
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
+
 
+
 
+
 
+
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
+
  
 +
Aby włączyć prywatne strony użytkowników należy odpowiednio skonfigurować poniższe linijki głównego pliku konfiguracyjnego UserDir /home/*/public_html
 +
#
 +
# Control access to UserDir directories. The following is an example
 +
# for a site where these directories are restricted to read-only.
 +
#
 +
AllowOverride FileInfo AuthConfig LimitOptions MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec
 +
Order allow,deny
 +
Allow from all
 +
Order deny,allow
 +
Deny from all
  
  
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