Odoo 服务器域名配置

Odoo 服务器域名配置

市场上的两大主流 Web 服务器无疑是 Apache 和 Nginx,Odoo 部署为 Web 站点时,显然不会采用 http://your.ip.address:8069的方式进行访问,于我们需要进行 Web 服务器的配置:

Read More

Nginx完整学习笔记(CentOS 7)

系统准备

Nginx安装

Read More

CentOS 7下通过uWSGI + Nginx部署Django

安装Python 3

wget https://www.python.org/ftp/python/3.6.0/Python-3.6.0.tgz
tar -xzvf Python-3.6.0.tgz -C  /tmp
cd  /tmp/Python-3.6.0/
./configure --prefix=/usr/local
make && make altinstall

安装Nginx

#add the CentOS 7 EPEL repository(/etc/yum.repos.d/)
sudo yum -y install epel-release
#安装Nginx
sudo yum -y install nginx
#启动Nginx
sudo systemctl start nginx
#如果运行了防火墙执行如下命令允许http和https的web访问
sudo firewall-cmd --permanent --zone=public --add-service=http 
sudo firewall-cmd --permanent --zone=public --add-service=https
sudo firewall-cmd --reload
#开机启动Nginx服务
sudo systemctl enable nginx

在浏览器中访问http://server_domain_name_or_IP/如果出现如下页面表明Nginx安装正常
Nginx启动页面
Nginx主配置文件:/etc/nginx/nginx.conf,可以看网站默认根目录在/usr/share/nginx/html,可通过在/etc/nginx/conf.d下添加.conf文件进行配置

安装MySQL

#安装MySQL,由于直接通过yum安装将会安装的是MariaDB
#需访问https://dev.mysql.com/downloads/repo/yum/查找对应的版本
wget https://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
rpm -ivh mysql57-community-release-el7-9.noarch.rpm
yum install -y mysql-server mysql-devel
#启动MySQL服务
systemctl start mysqld
#查找安装初始密码
grep 'temporary password' /var/log/mysqld.log
#修改密码删除多余的测试表
mysql_secure_installation

安装virtualenvwrapper

yum -y install python-setuptools python-devel
yum -y install python-pip
pip install virtualenvwrapper
#如果出现因安装过慢所导致的失败,进行如下配置
cd ~
mkdir .pip
cd .pip
vi pip.conf 
#放入如下内容保存退出
[global]  
index-url = https://pypi.doubanio.com/simple/  
[install]  
trusted-host=pypi.doubanio.com  
disable-pip-version-check = true  
timeout = 6000  

#也可在安装时直接使用pip install -i https://pypi.douban.com/simple package_name

编辑家目录下的.bashrc文件设置如下环境变量

export WORKON_HOME=$HOME/.virtualenvs
#可不设置export PROJECT_HOME=$HOME/project_directory
source /usr/bin/virtualenvwrapper.sh 
#重载.bashrc
source  ~/.bashrc
#新建虚拟环境
mkvirtualenv test

#过入本机,导出本地环境安装包
workon xxx
pip freeze > requirements.txt
#上传requirements.txt需部署机器
workon test
pip install -r requirements.txt


#安装uwsgi
pip install uwsgi

测试uwsgi是否安装正常

方法一: 创建test.py文件,添加如下代码

def application(env, start_response):
        start_response('200 OK', [('Content-Type','text/html')])
        return "Hello World"
#执行如下代码
uwsgi --http :8001 --wsgi-file test.py

浏览器访问http://your-ip:8001输出Hello World表示安装正常
方法二:

django-admin startproject testProject
cd testProject
uwsgi --http :8000 --module testProject.wsgi

浏览器访问http://your-ip:8000输出It worked页面表示安装正常

以上方法如无法访问,可能需要关闭防火墙:systemctl stop firewalld
如果从本地打包上传,在testProject/settings.py

#将DEBUG值修改为False
#注释以下部分
#STATICFILES_DIRS = [
#    os.path.join(BASE_DIR, 'static')
#]
#添加如下代码
STATIC_ROOT = os.path.join(BASE_DIR, 'static')

执行 python manage.py collectstatic

Nginx配置

在testProject主目录下创建uc_nginx.conf然后创建软链接
sudo ln -s 你的目录/testProject/uc_nginx.conf /etc/nginx/conf.d/
或者直接在/etc/nginx/conf.d/下创建uc_nginx.conf:

# the upstream component nginx needs to connect to
upstream django {
# server unix:///path/to/your/mysite/mysite.sock; # for a file socket
server 127.0.0.1:8000; # for a web port socket (we'll use this first)
}
# configuration of the server

server {
# the port your site will be served on
listen      80;
# the domain name it will serve for
server_name 192.168.0.16 www.yourdomain.com; # substitute your machine's IP address or FQDN
charset     utf-8;

# max upload size
client_max_body_size 75M;   # adjust to taste

# Django media
location /media  {
    alias /root/testProject/media;  # 指向django的media目录
}

location /static {
    alias /root/testProject/static; # 指向django的static目录
}

# Finally, send all non-media requests to the Django server.
location / {
    uwsgi_pass  django;
    include     uwsgi_params; # the uwsgi_params file you installed
}
}

#ssl配置
server {
# the port your site will be served on
listen   443;
ssl on;
ssl_certificate   /home/cert/yourcert.pem;
ssl_certificate_key  /home/cert/yourkey.key;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
# the domain name it will serve for
server_name www.yourdomain.com; # substitute your machine's IP address or FQDN
charset     utf-8;

# max upload size
client_max_body_size 75M;   # adjust to taste

# Django media
location /media  {
    alias /root/testProject/media;  # 指向django的media目录
}

location /static {
    alias /root/testProject/static; # 指向django的static目录
}

# Finally, send all non-media requests to the Django server.
location / {
    uwsgi_pass  django;
    include     /root/testProject/conf/uwsgi_params; # the uwsgi_params file you installed
}
}

重启Nginx
注:使用systemctl restart nginx.service有可能会出现权限问题

些时使用pkill -f nginx,执行如下命令启动nginx

sudo /usr/sbin/nginx

在根目录下/root/testProject添加conf/uwsgi.ini

# mysite_uwsgi.ini file
[uwsgi]

# Django-related settings
# the base directory (full path)
chdir           = /root/testProject
# Django's wsgi file
module          = testProject.wsgi
# the virtualenv (full path)

# process-related settings
# master
master          = true
# maximum number of worker processes
processes       = 10
# the socket (use the full path to be safe
socket          = 127.0.0.1:8000
# ... with appropriate permissions - may be needed
# chmod-socket    = 664
# clear environment on exit
vacuum          = true
virtualenv = /root/.virtualenvs/test
~                                     

启动

uwsgi -i /root/testProject/conf/uwsgi.ini &

Django的配置



接下来配置站点下的settings.py中数据库部分,创建app


python manage.py startapp blog
python manage.py makemigrations
python manage.py migrate

系统就会创建一些django默认表格,同样地可以测试启动站点

python manage.py runserver 0.0.0.0:9000

uwsgi

uwsgi --http :8000 --home /root/.virtualenvs/test --chdir /root/testsite/ -w testsite.wsgi
#停止所有uwsgi服务
ps -ef |grep uwsgi |awk '{print $2}'|xargs kill -9
#或使用如下命令自动关闭并重启
pkill -f uwsgi

设置定时任务

 

常见问题

1.Exception: you need a C compiler to build uWSGI
或Failed building wheel for mysql-python

yum install gcc  
//或执行
yum groupinstall "Development tools"

http://11hcw.me/setting-up-django-and-cloud-server-with-uwsgi-and-nginx/

2.environmenterror mysql_config not found

yum install -y mysql-devel

3.‘WSGIRequest’ object has no attribute ‘user’

访问http://your_ip:8000/admin时出现如上报错,将settings中的MIDDLEWARE改为MIDDLEWARE_CLASSES可以修复这一问题
4.出现以下报错需先安装MySQL

Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-vMcjZK/MySQL-python/
# 注:Python 3尚不能直接支持MySQL-python,请使用pip install mysqlclient

5.出现以下错误yum install gcc -y

error: command 'gcc' failed with exit status 1
  
  ----------------------------------------
  Failed building wheel for MySQL-python

6.ImportError: cannot import name patterns
根据提示找到对应文件,如Alan这里是由一个Ueditor插件所致,找到DjangoUeditor/urls.py删除掉patterns的import并修改掉urlpattern的写法

from django.conf.urls import patterns, url
修改为
from django.conf.urls import url
urlpatterns = patterns('',
    url(r'^controller/$',get_ueditor_controller)
)
修改为
urlpatterns = [
    url(r'^controller/$',get_ueditor_controller)
]

7.TemplateDoesNotExist
将本地项目移到线上,UEditor会报错,关闭调试在后台中查看详情或添加时均会报Server Error (500)
Exception Type: TemplateDoesNotExist
Exception Value: ueditor.html
相信会有更好的解决方法,Alan的处理方式是将相关的模板文件以及静态文件拷贝到对应目录

/root/.virtualenvs/yourproject/DjangoUeditor/templates/* extra_apps/xadmin/templates/
cp -R /root/.virtualenvs/yourproject/DjangoUeditor/static/* static/

参考文章:

初识Nginx

如何将django项目用Nginx部署到服务器

通过CentOS 7从零开始学习Linux及常见问题

本文将通过CentOS 7来学习Linux的以下常用知识:

  • Linux网络设置
  • SSH常用配置和使用方法
  • Linux常用服务
    • Crontab定时任务
    • NTP时间同步
    • Logrotate日志切割
    • Supervisor进程管理
  • Linux常用命令
  • Linux中的防火墙配置方法
  • 使用Apache配置Web服务器
  • 使用Nginx配置Web服务器
  • MySQL的安装及常用操作
  • Linux中的常见问题
  • Memcached和Redis缓存
  • Git的配置和使用
  • PHP安装及配置
    • Lavarel的安装及配置
    • Yii的安装及配置
    • ThinkPHP的安装及配置
    • phpMyAdmin的安装及配置
    • phpRedisAdmin的安装及配置
  • Java环境搭建
    • Tomcat搭建和启用
    • Maven使用示例
  • Python运行环境配置
  • Zabbix监控系统安装配置
  • VirtualBox 设置共享文件夹

CentOS 7目录结构

Read More

Nginx基础知识和常见问题

Nginx的基本支持

yum -y install gcc gcc-c++ autoconf automake

Nginx的常用组件

yum -y install zlib zlib-devel openssl openssl-devel pcre pcre-devel

安装Nginx

到官网http://nginx.org/下载最新的稳定版本(如nginx-1.10.0),上传到服务器

tar -xzvf nginx-1.10.0.tar.gz && cd nginx-1.10.0
./configure
make
sudo make install

常见问题一、make时出现如下报错:
make: *** No rule to make target build', needed by default’. Stop.
请安装本文开始处的组件(openssl openssl-devel pcre pcre-devel),然后执行
make clean
./configure
此时再执行make就恢复正常了

configue时可以添加参数来修改安装路径等相关内容,可执行./configure –help来查看所有选项。安装的默认目录为/usr/local/nginx/

Nginx的主配置文件为nginx.conf,以下为从网站摘抄的关于该配置文件的详细解释

#使用用户和用户组 user www www;
#user  nobody;
#指定工作进程数,一般根据cpu核数决定,如2核的值为2
worker_processes  2;
#指定错误日志路径,debug,info,notice,warn,error,crit
#crit级别最高,只记录非常严重的错误。
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
error_log  logs/error.log  info;
pid        logs/nginx.pid;
#指定文件描述符数量
#每个nginx进程打开文件描述符最大数目 配置要和系统的单进程打开文件数一
#致,linux 2.6内核下开启文件打开数为65535,worker_rlimit_nofile就相应
#应该填写65535 nginx调度时分配请求到进程并不是那么的均衡,假如超过会返回502错误。我
#这里写的大一点
worker_rlimit_nofile 51200;
events {
    #使用的网络i/o模型,linux为epoll,FreeBSD为kqueue
    use epoll;
    #允许连接数
    worker_connections  51200;
}
http {
    #设定mime类型
    include       mime.types;
    default_type  application/octet-stream; 
    #设置使用的字符集
    charset  utf-8;
     #设定日志格式
    #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()函数比read(2)和write(2)函数更加高效
    #后者需要从用户空间中传送文件。有时候会影响性能
sendfile        on;
#这个指令指定是否使用socket的TCP_NOPUSH(FreeBSD)或TCP_CORK(linux)选项,这个选项只在使用sendfile时有效。
    #设置这个选项的将导致nginx试图将它的HTTP应答头封装到一个包中。
    #tcp_nopush     on;     #参数的第一个值指定了客户端与服务器长连接的超时时间,超过这个时间,服务器将关闭连接。
    #参数的第二个值(可选)指定了应答头中Keep-Alive: timeout=time的time值,这个值可以使一些浏览器知道什么时候关闭连接,以便服务器不用重复关闭,如果不指定这个参数,nginx不会在应答头中发送Keep-Alive信息。(但这并不是指怎样将一个连接“Keep-Alive”)
    #参数的这两个值可以不相同。
    #keepalive_timeout  0 70;
    keepalive_timeout  65;
    #fastcgi用于php
    #这个参数指定将用多大的缓冲区来读取从FastCGI进程到来应答头。
#默认的缓冲区大小为fastcgi_buffers指令中的每块大小,可以将这个值设置更小。
    #fastcgi_buffer_size 64k;
    #fastcgi_buffers 4 64k;
    #指定是否启用gzip压缩。
    #gzip  on;
    #指定缓存压缩应答的缓冲区数量和大小
    #gzip_buffers 4 16K;
#指定压缩等级,其值从1到9,1为最小化压缩(处理速度快),9为最大化压缩(处理速度慢)。
    #gzip_comp_level 3;
    #使用正则表达式来指定某些不需要gzip压缩的浏览器(将和User-Agents进行匹配)。依赖于PCRE库
    #0.7.63版本以后,你可以为IE5.5和IE6 SP1使用msie6参数来禁止gzip压缩。
    #gzip_disable  "msie6";
    #设置允许压缩的页面最小字节数,页面字节数从header头中的Content-Length中进行获取。
    #默认值是0,不管页面多大都压缩。
    #建议设置成大于1k的字节数,小于1k可能会越压越大。
    #gzip_min_length 1;
    #Nginx作为反向代理的时候启用,开启或者关闭后端服务器返回的结果,匹配的前提是后端服务器必须要返回包含"Via"的 header头。
    #off - 关闭所有的代理结果数据的压缩
    #expired - 启用压缩,如果header头中包含 "Expires" 头信息
    #no-cache - 启用压缩,如果header头中包含 "Cache-Control:no-cache" 头信息
    #no-store - 启用压缩,如果header头中包含 "Cache-Control:no-store" 头信息
    #private - 启用压缩,如果header头中包含 "Cache-Control:private" 头信息
    #no_last_modified - 启用压缩,如果header头中不包含 "Last-Modified" 头信息
    #no_etag - 启用压缩 ,如果header头中不包含 "ETag" 头信息
    #auth - 启用压缩 , 如果header头中包含 "Authorization" 头信息
    #any - 无条件启用压缩
    #gzip_proxied
    #匹配MIME类型进行压缩,(无论是否指定)"text/html"类型总是会被压缩的。
    #gzip_types  text/plain application/x-javascript text/css text/html application/xml;
    #启用应答头“Vary: Accept-Encoding”,注意,由于一个bug将导致IE 4-6无法缓存内容。
    #gzip_vary on;
    upstream  backend  {
     server   127.0.0.1:8080     weight=5     max_fails=3  fail_timeout=30s;
    }
    server {
listen       192.168.56.1:80;
        server_name  www.server110.com;
        #charset utf-8;
  log_format  test  '$remote_addr - $remote_user [$time_local] $request '
'"$status" $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
         
        #access_log  logs/host.access.log  test;
        location / {
     proxy_pass http://backend;
     proxy_redirect     off;
     #保留用户真实信息
proxy_set_header   Host             $host;
proxy_set_header   X-Real-IP        $remote_addr;
proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
        }
 location ~ .*.(gif|jpg|jpeg|png|bmp|swf|js|css)$
  {
   expires      30d;
  }
  #location ~ .(htm|html|asp|php|gif|jpg|jpeg|png|bmp|ico|rar|css|js|
  #zip|java|jar|txt|flv|swf|mid|doc|ppt|xls|pdf|txt|mp3|wma)$ {
#    root /opt/webapp;
  #   expires 24h;
        #}
        #error_page  404              /404.html;
        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
root   html;
        }
        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ .php$ {
        #    proxy_pass   http://127.0.0.1;
        #}
        # pass the PHP scripts to FastCGI server listening on 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;
        #}
        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /.ht {
        #    deny  all;
        #}
    }
    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;     #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}
    # HTTPS server
    #
    #server {
    #    listen       443;
    #    server_name  localhost;     #    ssl                  on;
    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;
    #    ssl_session_timeout  5m;
    #    ssl_protocols  SSLv2 SSLv3 TLSv1;
    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers   on;
    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}
}

如何获取Nginx的进程号(pid)?

通过以下命令可直接打印出进程号:

ps -ef | grep "nginx: master process" | grep -v "grep" | awk -F ' ' '{print $2}'

也可以通过nginx.conf配置文件中pid对应文件来查看

通过这个pid我们可以进行关闭进程等操作,如平滑变更Nginx配置可使用kill -HUP 1126(假定pid为1126)

开启Nginx Status

在/etc/nginx/conf.d/default.conf的server配置中加入

    location /nginx_status 
    {
        stub_status on;
        access_log off;
    }

重启nginx(service nginx restart)

在命令行中输入curl http://127.0.0.1/nginx_status会得到类似如下的结果

# curl http://127.0.0.1/nginx_status
Active connections: 2 
server accepts handled requests
 25 25 74 
Reading: 0 Writing: 2 Waiting: 0 

 

如何在Nginx系统中开启Gzip

Nginx的gzip模块是内置的,在http中添加如下配置:

gzip on;
gzip_min_length  5k;
gzip_buffers     4 16k;
gzip_http_version 1.0;
gzip_comp_level 3;
gzip_types       text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
gzip_vary on;

 

配置指令详细注释:

gzip on|off
# 默认值: gzip off
# 开启或者关闭gzip模块

gzip_static on|off

# nginx对于静态文件的处理模块
# 该模块可以读取预先压缩的gz文件,这样可以减少每次请求进行gzip压缩的CPU资源消耗。该模块启用后,nginx首先检查是否存在请求静态文件的gz结尾的文件,如果有则直接返回该gz文件内容。为了要兼容不支持gzip的浏览器,启用gzip_static模块就必须同时保留原始静态文件和gz文件。这样的话,在有大量静态文件的情况下,将会大大增加磁盘空间。我们可以利用nginx的反向代理功能实现只保留gz文件。
# 可以google”nginx gzip_static”了解更多

gzip_comp_level 4

# 默认值:1(建议选择为4)
# gzip压缩比/压缩级别,压缩级别 1-9,级别越高压缩率越大,当然压缩时间也就越长(传输快但比较消耗cpu)。

gzip_buffers 4 16k

# 默认值: gzip_buffers 4 4k/8k
# 设置系统获取几个单位的缓存用于存储gzip的压缩结果数据流。 例如 4 4k 代表以4k为单位,按照原始数据大小以4k为单位的4倍申请内存。 4 8k 代表以8k为单位,按照原始数据大小以8k为单位的4倍申请内存。
# 如果没有设置,默认值是申请跟原始数据相同大小的内存空间去存储gzip压缩结果。

gzip_types mime-type [mime-type …]

# 默认值: gzip_types text/html (默认不对js/css文件进行压缩)
# 压缩类型,匹配MIME类型进行压缩
# 不能用通配符 text/*
# (无论是否指定)text/html默认已经压缩
# 设置哪压缩种文本文件可参考 conf/mime.types

gzip_min_length  1k

# 默认值: 0 ,不管页面多大都压缩
# 设置允许压缩的页面最小字节数,页面字节数从header头中的Content-Length中进行获取。
# 建议设置成大于1k的字节数,小于1k可能会越压越大。 即: gzip_min_length 1024

gzip_http_version 1.0|1.1

# 默认值: gzip_http_version 1.1(就是说对HTTP/1.1协议的请求才会进行gzip压缩)
# 识别http的协议版本。由于早期的一些浏览器或者http客户端,可能不支持gzip自解压,用户就会看到乱码,所以做一些判断还是有必要的。
# 注:99.99%的浏览器基本上都支持gzip解压了,所以可以不用设这个值,保持系统默认即可。
# 假设我们使用的是默认值1.1,如果我们使用了proxy_pass进行反向代理,那么nginx和后端的upstream server之间是用HTTP/1.0协议通信的,如果我们使用nginx通过反向代理做Cache Server,而且前端的nginx没有开启gzip,同时,我们后端的nginx上没有设置gzip_http_version为1.0,那么Cache的url将不会进行gzip压缩

gzip_proxied [off|expired|no-cache|no-store|private|no_last_modified|no_etag|auth|any] …

# 默认值:off
# Nginx作为反向代理的时候启用,开启或者关闭后端服务器返回的结果,匹配的前提是后端服务器必须要返回包含”Via”的 header头。
off – 关闭所有的代理结果数据的压缩
expired – 启用压缩,如果header头中包含 “Expires” 头信息
no-cache – 启用压缩,如果header头中包含 “Cache-Control:no-cache” 头信息
no-store – 启用压缩,如果header头中包含 “Cache-Control:no-store” 头信息
private – 启用压缩,如果header头中包含 “Cache-Control:private” 头信息
no_last_modified – 启用压缩,如果header头中不包含 “Last-Modified” 头信息
no_etag – 启用压缩 ,如果header头中不包含 “ETag” 头信息
auth – 启用压缩 , 如果header头中包含 “Authorization” 头信息
any – 无条件启用压缩

gzip_vary on

# 和http头有关系,加个vary头,给代理服务器用的,有的浏览器支持压缩,有的不支持,所以避免浪费不支持的也压缩,所以根据客户端的HTTP头来判断,是否需要压缩

gzip_disable “MSIE [1-6].”

# 禁用IE6的gzip压缩,又是因为杯具的IE6。当然,IE6目前依然广泛的存在,所以这里你也可以设置为“MSIE [1-5].”
# IE6的某些版本对gzip的压缩支持很不好,会造成页面的假死,今天产品的同学就测试出了这个问题
后来调试后,发现是对img进行gzip后造成IE6的假死,把对img的gzip压缩去掉后就正常了
为了确保其它的IE6版本不出问题,所以建议加上gzip_disable的设置

LNMP服务器配置WordPress站点

一键安装包LNMP环境搭建

一直以来都是使用LAMP服务器环境,但Nginx早就盛名在外了,所以这次有一个搭建新站的任务就决定尝试一下LNMP环境的搭建。本文中将暂不采用分别安装独立安装包的,而使用网上的一个一键安装包来完成,参考教程地址:http://lnmp.org/install.html

首先执行screen -S lnmp创建screen会话,出现如下提示

-bash: screen: command not found

于是安装screen:yum install screen -y,重新执行上述命令,然后获取一键安装包,同时解压并执行安装文件(安装文件百度网盘链接: http://pan.baidu.com/s/1o6latlg 密码: d259)

wget -c http://soft.vpser.net/lnmp/lnmp1.2-full.tar.gz && tar zxf lnmp1.2-full.tar.gz && cd lnmp1.2-full && ./install.sh lnmp

接着就开始设置MySQL的root账号密码

+------------------------------------------------------------------------+
|          LNMP V1.2 for CentOS Linux Server, Written by Licess          |
+------------------------------------------------------------------------+
|        A tool to auto-compile & install LNMP/LNMPA/LAMP on Linux       |
+------------------------------------------------------------------------+
|          For more information please visit http://www.lnmp.org         |
+------------------------------------------------------------------------+
Please setup root password of MySQL.(Default password: root)
Please enter:

确定是否需要开启InnoDB存储引擎

Do you want to enable or disable the InnoDB Storage Engine?
Default enable,Enter your choice [Y/n]: 

确定需安装的MySQLa或MariaDB的版本

You have 5 options for your DataBase install.
1: Install MySQL 5.1.73
2: Install MySQL 5.5.42 (Default)
3: Install MySQL 5.6.23
4: Install MariaDB 5.5.42
5: Install MariaDB 10.0.17
Enter your choice (1, 2, 3, 4 or 5):

确定所需安装的PHP版本

You have 5 options for your PHP install.
1: Install PHP 5.2.17
2: Install PHP 5.3.29
3: Install PHP 5.4.41 (Default)
4: Install PHP 5.5.25
5: Install PHP 5.6.9
Enter your choice (1, 2, 3, 4 or 5):

选择是否安装内存优化

You have 3 options for your Memory Allocator install.
1: Don't install Memory Allocator. (Default)
2: Install Jemalloc
3: Install TCMalloc
Enter your choice (1, 2 or 3): 

配置完成按任意键开始安装

Press any key to install...or Press Ctrl+c to cancel

安装成功后访问服务器ip地址后就会出现在/usr/local/nginx/conf/nginx.conf已配置的/home/wwwroot/default/index.html文件

Nginx安装完成页面

配置多站点

一键安装包已经自动在配置文件/usr/local/nginx/conf/nginx.conf中加入了include vhost/*.conf,因而可以在/usr/local/nginx/conf/vhost/文件夹下添加example.com.conf进行站点的配置。配置内容参考:

server {
        listen  80;
        server_name example.com www.example.com;
        location / {
            root   /var/www/example.com;
            index  index.php index.html index.htm;
        }
	}

location ~ \.php$ {

		root          /var/www/example.com;

		fastcgi_pass   127.0.0.1:9000;

		fastcgi_index  index.php;

		fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;

		include        fastcgi_params;

			}

直接安装Nginx

首先使用yum install nginx -y来进行nginx的安装

然后安装PHP, MySQL及常用的扩展

yum install httpd mysql php -y 
yum install php-devel php-fpm php-mysql php-gd libjpeg* php-imap php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-mcrypt php-bcmath php-mhash libmcrypt -y  
yum install mysql-server mysql mysql-devel -y

设置开机启动Nginx, MySQL和php-fpm

chkconfig nginx on

chkconfig mysqld on

chkconfig php-fpm on

执行service mysqld start启动MySQL服务,然后输入mysql_secure_installation设置数据库root密码并删除测试库数据。

执行service nginx start启动http服务,然后在浏览器中输入服务器ip,就会出现如下默认页面

Nginx默认访问页面

可以看出Nginx主配置文件在/etc/nginx/nginx.conf中,可以在该文件中发现include /etc/nginx/conf.d/*.conf,所以配置多站点的方法与上面相似,只需在/etc/nginx/conf.d/文件夹下创建一个conf文件即可。

我们刚刚访问的页面就是default.conf中配置的/usr/share/nginx/html下的index.html文件

安装Wordpress

首先在MySQL上创建数据库用于安装时使用,然后上传Wordpress安装文件或直接使用wget http://wordpress.org/latest.tar.gz下载最新版本然后解压到/var/www/example.com目录下

输入服务器IP或设置好解析的域名开启Wordpress的安装,这里就不再赘述。

我们着重讲一下Wordpress在Nginx的rewrite配置,我们都知道Wordpress默认的.htaccess文件是针对Apache的,要在Nginx下实现类似的重写规则就需要进行额外的配置。配置的方法是在前面的/etc/nginx/conf.d/example.com.conf文件中的location / 内加入如下代码

if (-f $request_filename/index.php){
	   rewrite (.*) $1/index.php;
}
if (!-f $request_filename){
		rewrite (.*) /index.php;
}