由于nginx不带有启动脚本,所以需要自己编辑一个
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
保存退出后加入service
chmod 755 /etc/init.d/nginx
chkconfig --add nginx
chkconfig nginx on
启动命令
service nginx start|restart|stop|reload|configtest
到这里,启动脚本就OK了。
由于nginx的配置文件过于简单,所以需要清空重新配置
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;
server
{
listen 80;
server_name localhost;
index index.html index.htm index.php;
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;
}
}
}
这个配置文件包含2大部分,一部分是nginx整体的配置,另一部分是服务部分
服务部分是虚拟主机,与apache一样的东西。
这两个部分也可以和apache一样分开,整体配置最后加入一行include vhosts/*.conf;并且把服务部分代码删除
然后在mkdir /usr/local/nginx/conf/vhosts/
vim /usr/local/nginx/conf/vhosts/default.conf
把服务部分放到default.conf配置文件中来。实现apache一样的功能。
这个配置有一个地方需要改动,第一行加入代码default_server 如下:
listen 80 default_server; 其中_server是可以省略的
一般来说,我们把默认的虚拟主机,不让解析,即用户访问为502.如下配置
server
{
listen 80 default_service;
server_name localhost;
index index.html index.htm index.php;
root /tmp/123; 专门配置一个空目录(如果不是空目录,下面需要deny)
#deny all;
}
下面不需要php解析了,因为就是不让用户访问,所以删除解析代码。
测试是否正确
1.service nginx configtest
2.curl -x127.0.0.1:80 localhost 提示403 也就是默认虚拟主机是403,达到我们的目的。
接下来创建我们自己的主机配置,在vhosts下创建wyp.conf
插入以下代码:
server
{
listen 80;
server_name llzdwyp.vicp.cc;
index index.html index.htm index.php;
root /usr/local/nginx/html; 网站根目录
location ~ \.php$ {
include fastcgi_params;
#fastcgi_pass unix:/tmp/php-fcgi.sock; socket(nginx监听方式)
fastcgi_pass 127.0.0.1:9000; IP(nginx监听方式)
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name;
(这里的网站根目录也需要更改)
}
}
nginx的监听方式用netstart来查看,一定要对应选择。否则会报错502
小技巧:ctrl+r可以搜索历史命令,与!vim类似。
课后答疑
1.如果我有两个虚拟主机配置文件默认是先执行哪个的
答:按ASCII码排序,看文件名,如果你的虚拟主机配置文件如下: 0.conf 1.conf a.conf 就会先执行0.conf 但是,如果你在a.conf里面有定义 listen 80 default_server; 则这个为默认主机。
2.铭哥,这里面的server部分是不是一定要拿出来单独放到一个文件去,如果不是,那我有多个网站的话是不是直接在后面添加一个server的内容就可以?
答:不用非得独立文件 也可以把配置写到nginx.conf里面。