CentOS+nginx+uwsgi+Python 多站点环境搭建

    xiaoxiao2021-04-17  40

    环境:

    CentOS X64 6.4

    nginx 1.5.6

    Python 2.7.5

    正文:

    一:安装需要的类库及Python2.7.5

    安装必要的开发包

    yum groupinstall "Development tools" yum install zlib-devel bzip2-devel pcre-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel

    CentOS 自带Python2.6.6,但我们可以再安装Python2.7.5:

    cd ~ wget http://python.org/ftp/python/2.7.5/Python-2.7.5.tar.bz2 tar xvf Python-2.7.5.tar.bz2 cd Python-2.7.5 ./configure --prefix=/usr/local make && make altinstall

    安装完毕后,可是使用”python2.7”命令进入python2.7的环境。

    二:安装Python包管理

    easy_install包 https://pypi.python.org/pypi/distribute

    方便安装Python的开发包

    cd ~ wget https://pypi.python.org/packages/source/d/distribute/distribute-0.6.49.tar.gz tar xf distribute-0.6.49.tar.gz cd distribute-0.6.49 python2.7 setup.py install easy_install --version

    红色部分必须是“python2.7”,否则将安装到默认的2.6环境内。

    pip包 https://pypi.python.org/pypi/pip

    安装pip的好处是可以pip list、pip uninstall 管理Python包, easy_install没有这个功能,只有uninstall

    easy_install pip pip --version

    三:安装uwsgi

    uwsgi:https://pypi.python.org/pypi/uWSGI

    uwsgi参数详解:http://uwsgi-docs.readthedocs.org/en/latest/Options.html

    pip install uwsgi uwsgi --version

    测试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://127.0.0.1:8001,看是否有“Hello World”输出,若没有输出,请检查你的安装过程。

    四:安装django

    pip install django

    测试django是否正常,运行:

    django-admin.py startproject demosite cd demosite python2.7 manage.py runserver 0.0.0.0:8002

    在浏览器内输入:http://127.0.0.1:8002,检查django是否运行正常。

    五:安装nginx

    cd ~ wget http://nginx.org/download/nginx-1.5.6.tar.gz tar xf nginx-1.5.6.tar.gz cd nginx-1.5.6 ./configure --prefix=/usr/local/nginx-1.5.6 \ --with-http_stub_status_module \ --with-http_gzip_static_module make && make install

    六:配置uwsgi

    uwsgi支持ini、xml等多种配置方式,但个人感觉ini更方便:

    在/ect/目录下新建uwsgi9090.ini,添加如下配置:

    [uwsgi] socket = 127.0.0.1:9090 master = true //主进程 vhost = true //多站模式 no-stie = true //多站模式时不设置入口模块和文件 workers = 2 //子进程数 reload-mercy = 10 vacuum = true //退出、重启时清理文件 max-requests = 1000 limit-as = 512 buffer-sizi = 30000 pidfile = /var/run/uwsgi9090.pid //pid文件,用于下面的脚本启动、停止该进程 daemonize = /website/uwsgi9090.log

    设置uwsgi开机启动,在/ect/init.d/目录下新建uwsgi9090文件,内容如下:

      uwsgi9090

    然后在终端执行:

    -- 添加服务 chkconfig --add uwsgi9090 -- 设置开机启动 chkconfig uwsgi9090 on

    七:设置nginx

    找到nginx的安装目录,打开conf/nginx.conf文件,修改server配置

    server { listen 80; server_name localhost; location / { include uwsgi_params; uwsgi_pass 127.0.0.1:9090; //必须和uwsgi中的设置一致 uwsgi_param UWSGI_SCRIPT demosite.wsgi; //入口文件,即wsgi.py相对于项目根目录的位置,“.”相当于一层目录 uwsgi_param UWSGI_CHDIR /demosite; //项目根目录 index index.html index.htm; client_max_body_size 35m; } }

    设置nginx开机启动,在/ect/init.d/目录下新建nginx文件,内容如下:

      nginx

    然后在终端执行:

    -- 添加服务 chkconfig --add nginx -- 设置开机启动 chkconfig nginx on

    八:测试

    OK,一切配置完毕,在终端运行

    service uwsgi9090 start service nginx start

    在浏览器输入:http://127.0.0.1,恭喜你可以看到django的“It work”了~

    九:多站配置

    我采用运行多个uwsgi服务的方法来实现多个站点。

    重复第六步,创建uwsgi9091.ini,并相应修改文件中的

    socket = 127.0.0.1:9091 pidfile = /var/run/uwsgi9091.pid daemonize = /website/uwsgi9091.log

    并创建服务uwsgi9091,设置开机启动。

    然后修改nginx的配置文件为:

      nginx

    然后我们就可以通过http://127.0.0.1:1300来访问新的网站了。

    十:其他配置

    防火墙设置

    CentOS默认关闭外部对80、3306等端口的访问,所以要在其他计算机访问这台服务器,就必须修改防火墙配置,打开/etc/sysconfig/iptables

    在“-A INPUT –m state --state NEW –m tcp –p –dport 22 –j ACCEPT”,下添加:

    -A INPUT -m state --state NEW -m tcp -p -dport 80 -j ACCEPT -A INPUT -m state --state NEW -m tcp -p -dport 3306 -j ACCEPT

    然后保存,并关闭该文件,在终端内运行下面的命令,刷新防火墙配置:

    service iptables restart

    安装Mysqldb

    yum -y install mysql-devel easy_install-2.7 MySQL-python

    注意红色部分,easy_install-2.7,否则它将默认安装到Python2.6环境内。

      

    ------------------------------------------------------------------------------------------------------------------ 

    2014年12月02日添加: 

    CentOS 7中默认使用Firewalld做防火墙,所以修改iptables后,在重启系统后,根本不管用。 

    Firewalld中添加端口方法如下: 

    firewall-cmd --zone=public --add-port=3306/tcp --permanent 

    firewall-cmd --reload

    转载请注明原文地址: https://ju.6miu.com/read-673948.html

    最新回复(0)