在ubuntu14.10上安装uwsgi+nginx

安装ubuntu 14.10服务器版,不用桌面版。

服务器安装时, 语言选 english,选中文的话,locale会是zh_CN,后面安装包会报没有语言包警告。

安装结束时,选择一个OpenSSH,可以直接使用 SecureCRT连接服务器进行操作。

不选择那个Landscape更新管理,听说它是60天免费试用。


1、修改apt更新源

国内源有搜狐,网易,阿里云。 我使用移动网,使用网易的源安不上pip,最后选的是sohu源。


deb http://mirrors.sohu.com/ubuntu/ utopic main restricted universe multiverse
deb http://mirrors.sohu.com/ubuntu/ utopic-security main restricted universe multiverse
deb http://mirrors.sohu.com/ubuntu/ utopic-updates main restricted universe multiverse
deb http://mirrors.sohu.com/ubuntu/ utopic-proposed main restricted universe multiverse
deb http://mirrors.sohu.com/ubuntu/ utopic-backports main restricted universe multiverse
deb-src http://mirrors.sohu.com/ubuntu/ utopic main restricted universe multiverse
deb-src http://mirrors.sohu.com/ubuntu/ utopic-security main restricted universe multiverse
deb-src http://mirrors.sohu.com/ubuntu/ utopic-updates main restricted universe multiverse
deb-src http://mirrors.sohu.com/ubuntu/ utopic-proposed main restricted universe multiverse
deb-src http://mirrors.sohu.com/ubuntu/ utopic-backports main restricted universe multiverse


使用sudo -s把自己变成root,不用每次输sudo,以下命令都省略sudo。


首先备份源列表:


vi cp /etc/apt/sources.list /etc/apt/sources.list_backup


而后用gedit或其他编辑器打开,在这里只能使用vi,或者nano:
vi /etc/apt/sources.list


按Esc 然后 dG, 全部删除内容。
按i键进入Insert模式,通过SecureCRT 粘贴进去。


2、配置网络

安装过程会有设置IP的对话框,不小心填错DNS。

vi /etc/network/interfaces

# The primary network interface
auto eth0
iface eth0 inet static
        address 192.168.11.36
        netmask 255.255.255.0
        network 192.168.11.0
        broadcast 192.168.11.255
        gateway 192.168.11.1
        # dns-* options are implemented by the resolvconf package, if installed
        dns-nameservers 114.114.114.114
        dns-search mz.com


重启网卡,让网络配置生效
ifdown eth0
ifup eth0


使用service networking restart 会报错 object failure。


3、安装uwsgi和nginx

ubuntu 14.10自带python 2.7.6, 做apt-get update后会升级到 2.7.8,不知道会不会不小心升级到python 3。

apt-get install python-pip

安装要占用130多M,不过还是划算。


安装uwsgi需要准备一下编译环境,否则会报找不到pytho.h错误。


apt-get install build-essential python
apt-get install python-dev


安装uwsgi
pip install uwsgi==2.0.8

pip会自己选择最新稳定版本,但我这里指定版本。


安装nginx
nginx=stable # use nginx=development for latest development version
add-apt-repository ppa:nginx/$nginx
apt-get update 
apt-get install nginx

使用的ppa方式。


安装 django 
pip install django==1.6

目前最新是1.7,但项目使用的包有的不支持,只能使用1.6。

安装 mysql
apt-get install mysql-server
这里安装的5.5.40版本,其中会提示输入root的密码,譬如 60240CC


4、配置uwsgi和nginx

新建了一个/etc/mz_conf/目录,把uwsgi和nginx的配置文件放在它下面。


配置nginx

cp /etc/nginx/uwsgi_params /etc/mz_conf/

在此目录创建nginx.conf

# nginx.conf

# the upstream component nginx needs to connect to
upstream django {
    server unix:///tmp/mz.sock; # for a file socket
    #server 127.0.0.1:8001; # 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.11.36; # substitute your machine's IP address or FQDN
    charset     utf-8;

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

    # Django media
    location /media  {
        alias /var/www/html/media;  # your Django project's media files - amend as required
    }

    location /static {
        alias /var/www/html/static; # your Django project's static files - amend as required
    }

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



创建符号链接,将nginx.conf链接到 /etc/nginx/conf.d/目录
ln -s /etc/mz_conf/nginx.conf /etc/nginx/conf.d/


注:

(1)使用socket,注意///格式,而且使用的文件要等同于uwsgi配置的文件。

(2)server_name,如是服务器有域名,填域名不会错;若网内测试,可以填IP地址。 填错了,会报404错误。

(3)报403 forbidden错误,需要把上传到html文件夹的内容,修改到755。 我是修改到755的。


配置uwsgi

在/etc/mz_config下建立uwsgi.ini


# uwsgi.ini file
[uwsgi]


# Django-related settings
# the base directory (full path)
chdir           = /var/www/html/
# Django's wsgi file
module          = mz.wsgi:application
# 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:8001
socket		 = /tmp/mz.sock
# ... with appropriate permissions - may be needed
chmod-socket    = 666
# clear environment on exit
vacuum          = true
process		= 4
threads		= 2



写成服务自启动,编辑 /etc/init/uwsgi.conf,并链接到vassals下: ln -s /etc/mz_conf/uwsgi.ini /etc/uwsgi/vassals/

description "uWSGI"
start on runlevel [2345]
stop on runlevel [06]
respawn


env UWSGI=/usr/local/bin/uwsgi
env LOGTO=/var/log/uwsgi-emperor.log


exec $UWSGI --master --emperor /etc/uwsgi/vassals --die-on-term --uid www --gid www --logto $LOGTO



要增加 www用户,命令:adduser www
不输入密码。

增加www组,命令: addgroup www

把www用户加到www组:adduser www www


做成service后,重启uwsgi和nginx,使用 service uwgis restart即可。


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。