LNMP之 nginx 启动脚本和配置文件
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LNMP之 nginx 启动脚本和配置文件相关的知识,希望对你有一定的参考价值。
因为 nginx 启动不方便,所以我们需要自已手动来编译一个nginx 的启动脚本
[[email protected] ~]# vim /etc/init.d/nginx #加入以下内容
#!/bin/bash
# chkconfig: - 30 21
# description: http service.
# Source Function Library
. /etc/init.d/functions
# Nginx Settings
NGINX_SBIN="/usr/local/nginx/sbin/nginx"
NGINX_CONF="/usr/local/nginx/conf/nginx.conf"
NGINX_PID="/usr/local/nginx/logs/nginx.pid"
RETVAL=0
prog="Nginx"
start() {
echo -n $"Starting $prog: "
mkdir -p /dev/shm/nginx_temp
daemon $NGINX_SBIN -c $NGINX_CONF
RETVAL=$?
echo
return $RETVAL
}
stop() {
echo -n $"Stopping $prog: "
killproc -p $NGINX_PID $NGINX_SBIN -TERM
rm -rf /dev/shm/nginx_temp
RETVAL=$?
echo
return $RETVAL
}
reload(){
echo -n $"Reloading $prog: "
killproc -p $NGINX_PID $NGINX_SBIN -HUP
RETVAL=$?
echo
return $RETVAL
}
restart(){
stop
start
}
configtest(){
$NGINX_SBIN -c $NGINX_CONF -t
return 0
}
case "$1" in
start)
start
;;
stop)
stop
;;
reload)
reload
;;
restart)
restart
;;
configtest)
configtest
;;
*)
echo $"Usage: $0 {start|stop|reload|restart|configtest}"
RETVAL=1
esac
exit $RETVAL
-----------------------------------------------------------------------
保存后,更改权限:
[[email protected] ~]# chmod 755 /etc/init.d/nginx # 更改权限
[[email protected] ~]# chkconfig --add nginx #加入到服务列表
[[email protected] ~]# chkconfig nginx on #开机启动
[[email protected] ~]# service nginx configtest #检查配置文件有没有问题
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
---------------------------------------------------------------------------
更改 nginx 配置文件
[[email protected] ~]# cp /usr/local/nginx/conf/nginx.conf /usr/local/nginx/conf/nginx.conf.bak
[[email protected] ~]# >/usr/local/nginx/conf/nginx.conf #清空nginx.conf 里的配置文件
[[email protected] ~]# vim /usr/local/nginx/conf/nginx.conf # 写入以下配置
user nobody nobody;
worker_processes 2;
error_log /usr/local/nginx/logs/nginx_error.log crit;
pid /usr/local/nginx/logs/nginx.pid;
worker_rlimit_nofile 51200;
events
{
use epoll;
worker_connections 6000;
}
http
{
include mime.types;
default_type application/octet-stream;
server_names_hash_bucket_size 3526;
server_names_hash_max_size 4096;
log_format combined_realip ‘$remote_addr $http_x_forwarded_for [$time_local]‘
‘$host "$request_uri" $status‘
‘"$http_referer" "$http_user_agent"‘;
sendfile on;
tcp_nopush on;
keepalive_timeout 30;
client_header_timeout 3m;
client_body_timeout 3m;
send_timeout 3m;
connection_pool_size 256;
client_header_buffer_size 1k;
large_client_header_buffers 8 4k;
request_pool_size 4k;
output_buffers 4 32k;
postpone_output 1460;
client_max_body_size 10m;
client_body_buffer_size 256k;
client_body_temp_path /usr/local/nginx/client_body_temp;
proxy_temp_path /usr/local/nginx/proxy_temp;
fastcgi_temp_path /usr/local/nginx/fastcgi_temp;
fastcgi_intercept_errors on;
tcp_nodelay on;
gzip on;
gzip_min_length 1k;
gzip_buffers 4 8k;
gzip_comp_level 5;
gzip_http_version 1.1;
gzip_types text/plain application/x-javascript text/css text/htm application/xml;
include vhosts/*.conf;
} # 注意这个括号以及这一句 include vhosts/*.conf;
--------------------------------------------------------------------
[[email protected] ~]# /usr/local/nginx/sbin/nginx -t # 检查nginx 的编译
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[[email protected] ~]# cd /usr/local/nginx/conf/
[[email protected] conf]# mkdir vhosts #创建 vhosts 目录
[[email protected] conf]# cd vhosts/
[[email protected] vhosts]# vim default.conf # 编辑default.conf ,写入以下内容
server
{
listen 80 default_server;
server_name localhost;
index index.html index.htm index.php;
root /tmp/1233; #黙认的虚拟主机设置为 空,访问是会是 403 ,如下图
deny all;
以下不用的注释或册除
# root /usr/local/nginx/html;
# location ~ \.php$ {
# include fastcgi_params;
# fastcgi_pass unix:/tmp/php-fcgi.sock;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name;
# }
}
niginx 启动(一定要检查nginx 是否正常启动)
[[email protected] vhosts]#mkdir /tmp/1223 #创建这个目录
[[email protected] vhosts]# /usr/local/nginx/sbin/nginx -t #编译完检查
[[email protected] vhosts]# /etc/init.d/nginx reload #重新加载配置文件
Reloading Nginx: [ OK ]
以下可以访问黙认主机的的情形反映
[[email protected] vhosts]# curl localhost
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
body {
width: 35em;
margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif;
}
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>
<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>
<p><em>Thank you for using nginx.</em></p>
</body>
</html>
楼主在编写另一个主机的时候,没有实现 502 的状态,不知何故。
以下 test.com 示例文件
server
{
listen 80;
server_name test.com;
index index.html index.htm index.php;
root /data/www;
location ~ \.php$ {
include fastcgi_params;
#fastcgi_pass unix:/tmp/php-fcgi.sock;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /data/www$fastcgi_script_name;
}
}
[[email protected] vhosts]# vim test.com
[[email protected] vhosts]# curl -x127.0.0.1:80 test.com
<html>
<head><title>403 Forbidden</title></head>
<body bgcolor="white">
<center><h1>403 Forbidden</h1></center>
<hr><center>nginx/1.10.2</center>
</body>
</html>
本文出自 “CBO#Boy_Linux之路” 博客,请务必保留此出处http://20151213start.blog.51cto.com/9472657/1870855
以上是关于LNMP之 nginx 启动脚本和配置文件的主要内容,如果未能解决你的问题,请参考以下文章