LNMP環境構築 - Nginx編
1.Nginx配置文件测试
<code>root<span>@kallen</span><span>:/usr/local/nginx/sbin</span><span># nginx -t </span><span>nginx:</span> the configuration file /etc/nginx/nginx.conf syntax is ok <span>nginx:</span> configuration file /etc/nginx/nginx.conf test is successful</code>
2.Nginx启动
<code>[root<span>@kallen</span> ~]<span># /usr/local/nginx/sbin/nginx </span></code>
3.Nginx负载均衡
Nginx 的upstream 目前支持4 种方式的分配——
(1)轮询(默认) :
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
(2)weight :
指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。
(3)ip_hash :
每个请求按访问ip 的hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决session 的问题。可以针对同一个C 类地址段中的客户端选择同一个后端服务器,除非那个后端服务器宕了才会换一个。
(4)fair(第三方):
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
(5)url_hash(第三方):
按访问url 的hash 结果来分配请求,使每个url 定向到同一个后端服务器,后端服务器为缓存时比较有效。
4.Nginx安装及配置
(1) nginx源码安装
<code>[root<span>@kallen</span> ~]<span># cd /usr/local/src/</span></code>
<code>[root<span>@kallen</span> ~]<span># wget http://syslab.comsenz.com/downloads/linux/nginx-0.9.6.tar.gz</span> [root<span>@kallen</span> ~]<span># tar zxvf nginx-0.9.6.tar.gz</span> [root<span>@kallen</span> ~]<span># cd nginx-0.9.6</span></code>
<code>./configure --prefix=/usr/local/nginx -<span>-sbin-path=<span>/usr/local</span><span>/nginx/sbin</span><span>/nginx </span></span>-<span>-conf-path=<span>/usr/local</span><span>/nginx/conf</span><span>/nginx.conf </span></span>-<span>-error-log-path=<span>/usr/local</span><span>/nginx/logs</span><span>/error.log </span></span>-<span>-http-log-path=<span>/usr/local</span><span>/nginx/logs</span><span>/access.log </span></span>-<span>-pid-path=<span>/usr/local</span><span>/nginx/var</span><span>/nginx.pid </span></span>-<span>-lock-path=<span>/usr/local</span><span>/nginx/var</span><span>/nginx.lock </span></span>-<span>-http-client-body-temp-path=<span>/dev/shm</span><span>/nginx_temp/client</span>_body </span>-<span>-http-proxy-temp-path=<span>/dev/shm</span><span>/nginx_temp/proxy</span></span>-<span>-http-fastcgi-temp-path=<span>/dev/shm</span><span>/nginx_temp/fastcgi</span></span>-<span>-user=www --group=www </span>-<span>-with-cpu-opt=pentium4F </span>-<span>-without-select_module </span>-<span>-without-poll_module </span>-<span>-with-http_realip_module </span>-<span>-with-http_sub_module </span>-<span>-with-http_gzip_static_module </span>-<span>-with-http_stub_status_module </span>-<span>-without-http_ssi_module </span>-<span>-without-http_userid_module </span>-<span>-without-http_geo_module </span>-<span>-without-http_memcached_module </span>-<span>-without-http_map_module </span>-<span>-without-mail_pop3_module </span>-<span>-without-mail_imap_module </span>-<span>-without-mail_smtp_module </span>-<span>-with-pcre=<span>/usr/local</span><span>/src/pcre</span>-<span>8.32</span>/ </span>-<span>-with-zlib=<span>/usr/local</span><span>/zlib</span></span></code>
<code>[root<span>@kallen</span> ~]<span># make && make install </span> [root<span>@kallen</span> ~]<span># mkdir /dev/shm/nginx_temp</span></code>
有的nginx版本编译时会因为pcre编译不过去,需要修改一下 --with-pcre=/usr/local/src/pcre-8.32
,前提是已经下载了pcre源码包pcre-7.8.tar.gz,并解压到/usr/local/src/pcre-8.32
,不需要编译pcre.
在实际安装过程中可能需要手动安装以下依赖包:
a. 安装依赖软件
<code><span>apt</span><span>-</span><span>get</span><span>-</span><span>-</span><span>install</span><span>-</span><span>suggests</span><span>install</span><span>gcc</span><span>g</span><span>+</span><span>+</span><span>make</span></code>
b. 下载相关软件
<code>wget http://jaist<span>.dl</span><span>.sourceforge</span><span>.net</span>/project/pcre/pcre/<span>8.35</span>/pcre-<span>8.35</span><span>.tar</span><span>.gz</span> wget http://zlib<span>.net</span>/zlib-<span>1.2</span><span>.8</span><span>.tar</span><span>.gz</span> wget http://www<span>.openssl</span><span>.org</span>/source/openssl-<span>1.0</span><span>.1</span>g<span>.tar</span><span>.gz</span> wget http://www<span>.canonware</span><span>.com</span>/download/jemalloc/jemalloc-<span>3.6</span><span>.0</span><span>.tar</span><span>.bz</span>2 wget http://tengine<span>.taobao</span><span>.org</span>/download/tengine-<span>2.0</span><span>.2</span><span>.tar</span><span>.gz</span></code>
c. 安装Pcre
<code> tar zxvf pcre-<span>8.35</span><span>.tar</span><span>.gz</span> cd pcre-<span>8.35</span> ./configure --prefix=/usr/local/pcre-<span>8.35</span> make && make install</code>
d. 安装Zlib
<code> tar zxvf zlib-<span>1.2</span><span>.8</span><span>.tar</span><span>.gz</span> cd zlib-<span>1.2</span><span>.8</span> ./configure --prefix=/usr/local/zlib-<span>1.2</span><span>.8</span> make && make install</code>
[ERROR]-1:
<code>./configure: error: <span>the</span> HTTP gzip module requires <span>the</span> zlib library. You can either disable <span>the</span> module <span>by</span><span>using</span><span>--without-http_gzip_module </span> option, <span>or</span> install <span>the</span> zlib library <span>into</span><span>the</span><span>system</span>, <span>or</span> build <span>the</span> zlib library statically <span>from</span><span>the</span> source <span>with</span> nginx <span>by</span><span>using</span><span>--with-zlib=<path> opti</span></code>
[ERROR]-2:
<code>configure: error: You need a C<span>++ compiler for C+</span>+ support. make[1]: *** [/usr/local/src/pcre-8.32/Makefile] Error 1 make[1]: Leaving directory <span>`/home/kallen/MyDOC/nginx-1.8.0'</span> make: *** [build] Error 2</code>
安装完成后的配置信息如下:
<code>[Nginx <span>Configuration</span> Summary] <span>Configuration</span> summary + using PCRE <span>library</span>: /usr/local/src/pcre-<span>8.32</span> + OpenSSL <span>library</span><span>is</span><span>not</span> used +using builtin md5 code + sha1 <span>library</span><span>is</span><span>not</span> found + using zlib <span>library</span>: /usr/local/zlib nginx path prefix:<span>"/usr/local/nginx"</span> nginx binary <span>file</span>:<span>"/usr/local/nginx/sbin/nginx"</span> nginx <span>configuration</span> prefix:<span>"/usr/local/nginx/conf"</span> nginx <span>configuration</span><span>file</span>:<span>"/usr/local/nginx/conf/nginx.conf"</span> nginx pid <span>file</span>:<span>"/usr/local/nginx/var/nginx.pid"</span> nginx error log <span>file</span>:<span>"/usr/local/nginx/logs/error.log"</span> nginx http <span>access</span> log <span>file</span>:<span>"/usr/local/nginx/logs/access.log"</span> nginx http client request <span>body</span> temporary files:<span>"/dev/shm/nginx_temp/client_body"</span> nginx http proxy temporary files:<span>"/dev/shm/nginx_temp/proxy"</span> nginx http fastcgi temporary files:<span>"/dev/shm/nginx_temp/fastcgi"</span> nginx http uwsgi temporary files:<span>"uwsgi_temp"</span> nginx http scgi temporary files:<span>"scgi_temp"</span></code>
(2) 编写nginx启动脚本
<code>[root<span>@kallen</span> init.d]<span># vi /etc/init.d/nginx</span></code>
写入以下内容:
<code><span>#!/bin/bash</span><span># </span><span># Startup script for the Nginx HTTP Server</span><span>#</span><span># Kallen Ding, Apr 23 2015</span>NGINX_PATH=<span>"/usr/local/nginx/"</span> OPTIONS=<span>"-c <span>${NGINX_PATH}</span>conf/nginx.conf"</span> prog=nginx nginx=<span>${NGINX_PATH}</span>sbin/nginx pidfile=/var/run/nginx.pid <span># Source function library.</span> . /etc/rc.d/init.d/functions <span><span>start</span></span>() { <span>echo</span> -n <span>"Starting <span>$prog</span>: "</span> daemon --pidfile=<span>${pidfile}</span><span>$nginx</span><span>$OPTIONS</span> RETVAL=$? <span>echo</span><span>return</span><span>$RETVAL</span> } <span><span>stop</span></span>() { <span>echo</span> -n <span>"Stopping <span>$prog</span>: "</span> killproc -p <span>${pidfile}</span><span>$nginx</span> RETVAL=$? <span>echo</span> } <span><span>reload</span></span>() { <span>echo</span> -n $<span>"Reloading <span>$prog</span>: "</span> killproc -p <span>${pidfile}</span><span>$nginx</span> -HUP RETVAL=$? <span>echo</span> } <span># See how we were called.</span><span>case</span><span>"<span>$1</span>"</span><span>in</span> start) start ;; stop) stop ;; restart) stop start ;; reload) reload ;; status) status <span>$prog</span> RETVAL=$? ;; *) <span>echo</span><span>"Usage: <span>$prog</span> {start|stop|restart|reload|status}"</span> RETVAL=<span>3</span><span>esac</span><span>exit</span><span>$RETVAL</span></code>
保存后,更改/etc/init.d/nginx
的权限
<code>[root<span>@kallen</span> ~]<span># chmod 755 /etc/init.d/nginx</span> [root<span>@kallen</span> ~]<span># chkconfig --add nginx</span> [root<span>@kallen</span> ~]<span># chkconfig nginx on</span></code>
以上就介绍了LNMP环境搭建——Nginx篇,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Windowsでnginxを構成する方法は? nginxをインストールし、仮想ホスト構成を作成します。メイン構成ファイルを変更し、仮想ホスト構成を含めます。 nginxを起動またはリロードします。構成をテストし、Webサイトを表示します。 SSLを選択的に有効にし、SSL証明書を構成します。ファイアウォールを選択的に設定して、ポート80および443のトラフィックを許可します。

nginxが開始されるかどうかを確認する方法:1。コマンドラインを使用します:SystemCTLステータスnginx(Linux/unix)、netstat -ano | FindStr 80(Windows); 2。ポート80が開いているかどうかを確認します。 3.システムログのnginx起動メッセージを確認します。 4. Nagios、Zabbix、Icingaなどのサードパーティツールを使用します。

すべてのコンテナ(Docker PS)をリストする手順に従って、Dockerコンテナ名を照会できます。コンテナリストをフィルタリングします(GREPコマンドを使用)。コンテナ名(「名前」列にあります)を取得します。

Docker Containerの起動手順:コンテナ画像を引く:「Docker Pull [Mirror Name]」を実行します。コンテナの作成:「docker create [options] [mirror name] [コマンドとパラメーター]」を使用します。コンテナを起動します:「docker start [container name or id]」を実行します。コンテナのステータスを確認してください:コンテナが「Docker PS」で実行されていることを確認します。

Dockerでコンテナを作成します。1。画像を引く:Docker Pull [ミラー名]2。コンテナを作成:Docker Run [Options] [Mirror Name] [コマンド]3。コンテナを起動:Docker Start [Container Name]

nginxバージョンを照会できるメソッドは次のとおりです。nginx-vコマンドを使用します。 nginx.confファイルでバージョンディレクティブを表示します。 nginxエラーページを開き、ページタイトルを表示します。

クラウドサーバーでnginxドメイン名を構成する方法:クラウドサーバーのパブリックIPアドレスを指すレコードを作成します。 NGINX構成ファイルに仮想ホストブロックを追加し、リスニングポート、ドメイン名、およびWebサイトルートディレクトリを指定します。 nginxを再起動して変更を適用します。ドメイン名のテスト構成にアクセスします。その他のメモ:SSL証明書をインストールしてHTTPSを有効にし、ファイアウォールがポート80トラフィックを許可し、DNS解像度が有効になることを確認します。

NGINXサーバーがダウンすると、次のトラブルシューティング手順を実行できます。NGINXプロセスが実行されていることを確認します。エラーメッセージのエラーログを表示します。 nginx構成の構文を確認します。 nginxには、ファイルにアクセスするために必要な権限があることを確認してください。ファイル記述子をチェックして制限を開いてください。 Nginxが正しいポートで聴いていることを確認してください。 nginxトラフィックを許可するために、ファイアウォールルールを追加します。バックエンドサーバーの可用性を含む逆プロキシ設定を確認します。さらなる支援については、テクニカルサポートにお問い合わせください。
