


Comment déployer la configuration nginx, php et hôte virtuel dans l'environnement CentOS
Temps de déploiement : 2012-07-24
environnement os : centos 6.1
nginx : nginx-1.2.2
php:php5.3.14
0.
Copier le code Le code est le suivant :
yum install openssl-devel pcre-devel zlib-devel libjpeg-devel libpng-devel freetype-devel gcc make #🎜🎜 #
1. Ajouter un utilisateur www pour exécuter nginxmkdir -p / var/tmp/nginx/client/
mkdir -p /var/tmp/nginx/proxy/mkdir -p /var/tmp/nginx/fcgi/# 🎜🎜#
3, Téléchargez la dernière version stable du code source de nginx
Copiez le code Le code est le suivant :
wget http://nginx .org/download/nginx-1.2.2.tar.gz
4 Décompressez, compilez et installez
#. 🎜🎜#
tar vxzf nginx-1.2.2.tar.gz
. /configure
--prefix=/opt/web/nginx #🎜🎜 #--error-log-path=/var/log/nginx/error.log--pid-path=/var /run/nginx/nginx.pid
--lock-path=/ var/lock/nginx.lock
--user=www
--group=www
-- with-http_ssl_module
--with-http_stub_status_module
--with -http_gzip_static_module
--http-log-path=/var/log/nginx/access.log
--http -client-body-temp-path=/var/tmp/nginx/client/ # 🎜🎜#--http-proxy-temp-path=/var/tmp/nginx/proxy/
--http-fastcgi -temp-path=/var/tmp/nginx/fcgi/
- -http-uwsgi-temp-path=/var/tmp/nginx/uwsgi/
make
make install#🎜 🎜#
5, configurez nginx
# 🎜🎜#Copier le code Le code est le suivant :
vim /opt/web/nginx/conf/nginx. conf
# Spécifiez l'utilisateur de démarrage :
# Nombre de processus, l'auteur de nginx pense qu'un seul suffit, modifiez-le en fonction de votre propre trafic
worker_processes 1;#🎜 🎜## Définir le journal des erreurs :
#error_log logs/error.log info ;
error_log /var/log/nginx/error.default.log ;pid /opt/web/nginx/nginx.pid;
events {# 🎜🎜#use epoll;
worker_connections 1024;
}
http {#🎜 🎜#charset utf-8;
include mime.types;
default_type application/octet -stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '# 🎜🎜## '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
tcp_nopush activé;
tcp_nodelay activé;
#keepalive_timeout 0;#🎜 🎜 #keepalive_timeout 65;
gzip activé; 🎜🎜#gzip_proxyed tout ; /xml
application/atom+xml text/javascript;
server {
listen 80;
server_name localhost;
charset utf-8;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
}
#error_page 404/404. html;
# rediriger les pages d'erreur du serveur vers la page statique /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {# 🎜🎜#root html;
}
# proxy les scripts php vers apache en écoute sur 127.0.0.1:80
#
#location ~ .php$ {
# proxy_pass http://127.0.0.1;
#}
# transmet les scripts php au serveur fastcgi en écoute sur 127.0.0.1:9000
#
location ~ .php$ {# 🎜🎜#root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
#fastcgi_param script_filename /scripts$fastcgi_script_name;
#include fastcgi_params;#🎜 🎜# include fastcgi.conf;
}
# refuser l'accès aux fichiers .htaccess, si la racine du document d'Apache
# concorde avec celle de nginx
#
location ~ /.ht {
deny all;
}
}
# un autre hôte virtuel utilisant un mélange de configuration basée sur l'adresse IP, le nom et le port
#
#serveur {
# écouter 8000;
# écouter un nom:8080;
# nom_serveur un nom alias un autre.alias;
# emplacement / {
# racine html;#🎜🎜 ## index index.html index.htm;
# }
#}
# serveur https
#
#serveur {
# écoute 443;# 🎜🎜## nom_serveur localhost;
# ssl activé;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;
# ssl_session_timeout 5m;#🎜 🎜## s sl_protocoles sslv2 sslv3 tlsv1;
# ssl_ciphers high:!anull:!md5;
# ssl_prefer_server_ciphers on;
# emplacement / {
# racine html;
# index index.html index.htm;
# }
#}
proxy_read_timeout 200;
# réessayez uniquement s'il y a eu une erreur de communication, pas un délai d'attente
# sur le serveur tornado ( pour éviter de propager des "requêtes de mort"
# à tous les frontends)
proxy_next_upstream error;
proxy_set_header x-scheme $scheme;
proxy_set_header x-real-ip $remote_addr;#🎜 🎜#proxy_set_header host $host;
proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for;
# Introduire le fichier d'hôte virtuel
include /opt/web/nginx/conf/sites/*.conf;# 🎜🎜#}
6. Créez le répertoire où est stocké le fichier de configuration de la machine virtuelle
Copier le code Le code est le suivant :
# 🎜🎜#mkdir /opt /web/nginx/conf/sites
Après cette configuration, si vous devez ajouter un nouvel hôte virtuel, ajoutez le fichier de configuration directement dans le répertoire nginx/conf/sites/
Par exemple : vous avez maintenant le nom de domaine www.jb51.net
Créez : /opt/ web/nginx/conf/ Le contenu du fichier sites/www.jb51.net.conf
est le suivant :
Copiez le code Le code est le suivant :
server {
listen 80;
client_max_body_size 10m;
#Plusieurs noms de domaine sont séparés par des espaces, le premier est le nom par défaut
server_name www.jb51.net jb51.net;
charset utf-8;
index index.html index.htm index.php;
# Définir le répertoire racine
set $root /var/webroot/www.jb51.net/;
# Définir le chemin du site
root $root;
# Empêcher la navigation dans le répertoire
autoindex off;
if ($host != 'www.jb51.net' ) {
rewrite ^/(.*)$ //www.jb51.net/ $1 permanent;
}
# Empêcher la demande de fichiers .htaccess
location ~ /.ht {
deny all;
}
error_page 404 / 404.html;
index index.html index.htm;
location /uploads/ {
alias /data/webroot/www.jb51.net/uploads/;
}
try_files $uri @uwsgi;
location @uwsgi{
# Transférer les autres requêtes vers uwsgi
include uwsgi_params;
uwsgi_pass unix:/tmp/360ito_uwsgi .sock;
proxy_set_header x-real-ip $remote_addr;
proxy_set_header host $host;
proxy_set_header x-forwarded-for $proxy_add_x_for warded_for;
#proxy_pass http://localhost:5000;
}
# Transférer les requêtes de type php Donnez fastcgi
emplacement ~ .php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi.conf;
}
# Journal d'accès :
access_log /var/log/nginx/access .www.jb51.net.log;
# Chargez le fichier de réécriture .htaccess Notez que les chemins de variables ne sont pas pris en charge ici
# ne peut pas être écrit comme include $. root/www.jb51.net/.htaccess;
# include /var/webroot/ www.jb51.net/.htaccess;
# Activez le saut de nom de domaine, puis lorsque l'erreur d'accès se produit, les autres noms de domaine passeront automatiquement à www.jb51.net
# Remarque, ce dont je parle ici, c'est que ce n'est que lorsque l'erreur d'accès se produit qu'elle sautera, donc la redirection 301 ne peut pas être implémentée ici !
server_name_in_redirect on;
}
7. Installez la dernière version de php (php5.3.14)
Copiez le code Le code est le suivant :
cd /usr/local/src/
wget http://cn .php.net/get /php-5.3.14.tar.bz2/from/this/mirror
tar xjvf php-5.3.14.tar.bz2
cd php-5.3.14
Exécution :
Copier le code Le code est le suivant :
. /buildconf --force
Si une erreur est signalée, il se peut que votre autoconf ne soit pas la version 2.13. Pour les bugs de la série php5.3, vous devez installer la version 2.13 d'autoconf :
.
Copiez le code Le code est le suivant :
centos : # yum install autoconf213
debian : # apt-get install autoconf2.13
Définir les variables d'environnement
Copier le code Le code est le suivant :
# centos :
export php_autoconf="/usr/bin/autoconf-2.13"
# debian:
export php_autoconf="/usr/bin/autoconf2.13"
Exécutez à nouveau : ./buildconf --force, si buildconf : version autoconf 2.13 (ok)
apparaît, cela signifie succès.
Compilez et installez php
Copiez le code Le code est le suivant :
./configure
--prefix=/opt/web/php
--with-config-file-path=/opt/web/php /etc
-- with-config-file-scan-dir=/opt/web/php/etc/conf.d
--enable-fpm
--with-fpm-user=www
--with-fpm- group=www
- -with-mysql=/opt/db/percona-server-5.5.14-rel20.5
--with-mysqli=/opt/db/percona-server-5.5.14-rel20.5/ bin/mysql_config
- -with-iconv-dir
--with-freetype-dir
--with-jpeg-dir
--with-png-dir
--with-zlib
--with-libxml-dir
--enable-xml
--enable-mbstring
--with-gd
--enable-gd-native-ttf
--with-openssl
--enable-inline-optimization
make && make install
cp php. ini-production /opt /web/php/etc/php.ini
cd /opt/web/php/etc
cp php-fpm.conf.default php-fpm.conf
Modifiez php-fpm.conf pour activer le les lignes suivantes, c'est-à-dire supprimer les lignes précédentes Le point-virgule (;)
Copier le code Le code est le suivant :
pid = run/php-fpm.pid
error_log = log/php-fpm.log
log_level = notice
listen = 127.0.0.1:9000
listen. Allowed_clients = 127.0.0.1
listen.owner = www
listen.group = www
listen.mode = 0666
user = www
group = www
pm = dynamique
pm. max_children = 50
pm.start_servers = 17
pm. min_spare_servers = 17
pm.max_spare_servers = 35
pm.max_requests = 500
env[nom d'hôte] = $nom d'hôte
env[chemin] = /usr/local/bin:/usr /bin:/bin
env[tmp] = / tmp
env[tmpdir] = /tmp
env[temp] = /tmp
8. Démarrez php-fpm
Copiez le code Le code est le suivant :
/opt/web/php/sbin/php-fpm
Démarrez nginx
Copier le code Le code est le suivant :
/opt/web/nginx/sbin/nginx
9. Testez-le
Copie. code Le code est le suivant :
vim /var/webroot/www.jb51.net/tz .php
Entrez et enregistrez
Copier le code Le code est le suivant :
phpinfo() ;
?>
10. Entrez : http://php.jb51.net/tz.php dans la barre d'adresse du navigateur. En cas de succès, vous pouvez voir les informations affichées par phpinfo().
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

L'accès au fichier du site WordPress est restreint: dépannage de la raison pour laquelle le fichier .txt ne peut pas être accessible récemment. Certains utilisateurs ont rencontré un problème lors de la configuration du nom de domaine commercial du programme MINI: � ...

Exécuter plusieurs versions PHP simultanément dans le même système est une exigence commune, en particulier lorsque différents projets dépendent de différentes versions de PHP. Comment être sur la même chose ...
