当前位置: 澳门新濠3559 > 编程 > 正文

这里使用root账号登录,KVM WEB管理工具webvirtmgr安

时间:2019-12-08 22:39来源:编程
usedatabase_name; 3.gunicorn+nginx+django快捷部署 以下为具体操作: 1)环境准备:安装django,nginx,gunicore sudo brew install nginx(sudo apt-get install nginx) sudo pip install django sudo pip install gunicorn 2)配

use database_name;

3.gunicorn+nginx+django快捷部署

以下为具体操作:

1)环境准备:安装django,nginx,gunicore

sudo brew install nginx(sudo apt-get install nginx)

sudo pip install django

sudo pip install gunicorn

2)配置nginx

在/etc/nginx/sites-available/目录下创建 配置文件(文件名不限)

mac下是:/usr/local/etc/nginx/nginx.conf

server {

listen 9600;监听的服务器端口号,小于1024的端口号,需要sudo权限。由于做了gunicore映射,这里随便用个port就可以,用户实际访问时,请求的是gunicore绑定的端口。

server_name localhost;

server_name 127.0.0.1;此处应该改为公网 IP地址

access_log /opt/logs/nginx/wasp_ticket_stat.log;

error_log /opt/logs/nginx/wasp_ticket_stat_error.log;

*    location / {*

*        proxy_pass

*        proxy_set_header Host $host;*

*        proxy_set_header X-Real-IP $http_x_real_ip;*

*        proxy_set_header X-Forwarded-For $proxy_add_x_这里使用root账号登录,KVM WEB管理工具webvirtmgr安装和使用。forwarded_for;*

*    }*

}配置结束

保存后,启动nginx:sudo nginx

3)配置gunicorn

cd到django工程目录,gunicore project.wsgi –bind 0.0.0.0:8000 –deamon或者nohup gunicore project.wsgi –bind 0.0.0.0:8000

这么做是要保证,从部署服务器logout之后,gunicorn进程仍然活动。

gunicore第一个输入,就是要找到你project的wsgi,“.”表示目录级,可以挨个文件夹去找着自带的wsgi.py在哪里,默认在project内的project同名文件夹里。

如果成功了,则可以通过server公网ip:8000来访问网站。如果绑定80端口,则可以直接使用ip来访问。注意绑定小于1024的端口号时,需要sudo权限。

安装并配置Supervisor

Superviosr是一个进程监管的工具。简而言之,Superviosr可以保证你的程序在服务器开机时自动启动以及程序意外终止时重新启动。

  • 安装
sudo apt-get install supervisor
  • 配置

supervisor的配置文件默认从/etc/supervisor/conf.d中读取

cd /etc/supervisor/conf.d

创建并编辑一个supervisor的配置文件

sudo vim alpfaceblog.conf 

添加下面内容,注意路径需要根据实际情况替换

[program:DjangoBlog]
command = /var/www/Blog/bin/django_start
user = root
autostart=true
autorestart=true

redirect_stderr = true
stdout_logfile = /root/logs/blog/robot.log
stderr_logfile=/root/logs/blog/err.log  

手动创建日志目录:

mkdir -p /root/logs/blog

上面一步我们使用了django_start,这里我们在项目的bin目录下创建下它, 路径需要根据实际情况替换:

sudo vim django_start

#!/bin/bash

NAME="DjangoBlog" # Name of the application
DJANGODIR=/var/www/Blog # Django project directory
SOCKFILE=/var/www/Blog/run/gunicorn.sock # we will communicte using this unix socket
USER=root # the user to run as
GROUP=root # the group to run as
NUM_WORKERS=3 # how many worker processes should Gunicorn spawn
DJANGO_SETTINGS_MODULE=DjangoBlog.settings # which settings file should Django use
DJANGO_WSGI_MODULE=DjangoBlog.wsgi # WSGI module name

echo "Starting $NAME as `whoami`"

# Activate the virtual environment
cd $DJANGODIR
source /home/parallels/.virtualenvs/alpfaceblog/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH

# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

# Start your Django Unicorn
# Programs meant to be run under supervisor should not daemonize themselves (do not use --daemon)
exec /home/parallels/.virtualenvs/alpfaceblog/bin/gunicorn ${DJANGO_WSGI_MODULE}:application 
--name $NAME 
--workers $NUM_WORKERS 
--user=$USER --group=$GROUP 
--bind=unix:$SOCKFILE 
--log-level=debug 
--log-file=-

通过supervisorctl工具来启用这些设置:

sudo supervisorctl update
sudo supervisorctl reload  

这里我遇到了启动错误信息:

pkg_resources.DistributionNotFound: The 'supervisor==3.2.0' distribution was

解决方法:
这是由于我把ubuntu的python默认环境改成3.5的了,其实再改回2.7就好了

切换Python版本
sudo update-alternatives --install /usr/bin/python python /usr/bin/python2 200
sudo update-alternatives --install /usr/bin/python python /usr/bin/python3 100

澳门新濠3559 1

删除数据库

4.静态文件处理

如上的部署方式,做了两次web容器映射,最容易出bug的就是路径。web的开发环境肯定跟生产环境是隔离的,使用绝对路径非常蠢,运维很容易出错。且django对绝对路径进行了重定向,使用的绝对路径和系统路径并不完全一致。

相对路径由于多次映射的原因,很容易找不到/找错了,反复试验后,觉得如下配置比较轻便:

settings.py:末尾加上

STATIC_URL = '/static/'

STATICFILES_DIRS = (os.path.join(BASE_DIR, 'static').replace('\', '/'),)

urls.py末尾加上

from django.contrib.staticfiles.urls import staticfiles_urlpatterns

from django.contrib import staticfiles

urlpatterns += staticfiles_urlpatterns()

在项目根目录建立static/文件夹,各处用/statictest.jpg访问文件即可。

ps:从django脚本访问文件,与从模版访问是不同的。脚本访问文件的根目录是就是django项目的根目录,在views.py打印一下执行目录,一目了然:

for item in os.walk('.'):

    print item

5.跨域访问

在有些linux上,由于安全策略的关系,需要指定可用的安全ip。在settings.py里面,KNOWN_HOSTS这个list里面加上server ip

准备工作:

  • 创建一个django项目
  • 创建一个python虚拟环境
  • 激活虚拟环境
    这里跳过准备工作,假设我已经有了一个项目DjangoBlog和一个虚拟环境alpfaceblog

1 安装支持的软件源
yum -y install
2 安装相关软件
yum -y install git python-pip libvirt-python libxml2-python python-websockify supervisor nginx
3 从git-hub中下载相关的webvirtmgr代码
cd /usr/local/src/
git clone git://github.com/retspen/webvirtmgr.git
4 安装webvirtmgr
cd webvirtmgr/
pip install -r requirements.txt
5 安装数据库
yum install python-sqlite2
6 对django进行环境配置
 ./manage.py syncdb
You just installed Django's auth system, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): yes
Username (leave blank to use 'root'): admin
Email address: 2733176200@qq.com
Password:*********
Password (again):*********
 
 ./manage.py collectstatic #生成配置文件
./manage.py createsuperuser #添加管理员账号
 
7 拷贝web到 相关目录
cd ..
mkdir -pv /var/www
cp -Rv webvirtmgr /var/www/webvirtmgr
 
8 设置ssh
ssh-keygen
ssh-copy-id 192.168.2.32
ssh 192.168.2.32 -L localhost:8000:localhost:8000 -L localhost:6080:localhost:6080
 
9 编辑nginx配置文件
vim /etc/nginx/conf.d/webvirtmgr.conf 添加下面内容到文件中
server {
    listen 80 default_server;
 
    server_name $hostname;
    #access_log /var/log/nginx/webvirtmgr_access_log;
 
    location /static/ {
        root /var/www/webvirtmgr/webvirtmgr; # or /srv instead of /var
        expires max;
    }
 
    location / {
        proxy_pass ;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-for $proxy_add_x_forwarded_for;
        proxy_set_header Host $host:$server_port;
        proxy_set_header X-Forwarded-Proto $remote_addr;
        proxy_connect_timeout 600;
        proxy_read_timeout 600;
        proxy_send_timeout 600;
        client_max_body_size 1024M; # Set higher depending on your needs
    }
}
 
 
mv /etc/nginx/conf.d/default.conf /etc/nginx/conf.d/default.conf.bak
 
10 启动nginx
/etc/init.d/nginx restart
 
11 修改防火墙规则
/usr/sbin/setsebool httpd_can_network_connect true
 
 
12 设置 supervisor
chown -R nginx:nginx /var/www/webvirtmgr
vim /etc/supervisord.conf #在文件末尾添加
[program:webvirtmgr]
command=/usr/bin/python /var/www/webvirtmgr/manage.py run_gunicorn -c /var/www/webvirtmgr/conf/gunicorn.conf.py
directory=/var/www/webvirtmgr
autostart=true
autorestart=true
logfile=/var/log/supervisor/webvirtmgr.log
log_stderr=true
user=nginx
 
[program:webvirtmgr-console]
command=/usr/bin/python /var/www/webvirtmgr/console/webvirtmgr-console
directory=/var/www/webvirtmgr
autostart=true
autorestart=true
stdout_logfile=/var/log/supervisor/webvirtmgr-console.log
redirect_stderr=true
user=nginx
 
 
修改/var/www/webvirtmgr/conf/gunicorn.conf.py
bind = "0:8000"
 
13 设置开机启动
chkconfig supervisord on
vim /etc/rc.local
/usr/sbin/setsebool httpd_can_network_connect true
 
 
 
14 启动进程
/etc/init.d/supervisord restart
 
15查看进程
netstat -lnpt 即可以看到6080和8000已经启动
 
16 web访问

show variables like 'character_set_database';

1.协议:wsgi

wsgi相当于是python定制版的cgi,通用于所有的python web框架。wsgi/cgi的存在意义在于,确立了一套服务端脚本模式的标准,让服务器支持动态页面。之所以称之为协议,是因为其中只定义了接口标准,而没有规定实现方法,你可以基于任何语言/平台去实现它。

安装并配置nginx

  • 安装nginx
sudo apt-get install nginx

ubantu安装完Nginx后,文件结构大致为:
  所有的配置文件都在 /etc/nginx下;
  启动程序文件在 /usr/sbin/nginx下;
  日志文件在 /var/log/nginx/下,分别是access.log和error.log;
  并且在 /etc/init.d下创建了启动脚本nginx。

sudo /etc/init.d/nginx start # 启动
sudo /etc/init.d/nginx stop # 停止
sudo /etc/init.d/nginx restart # 重启

  • 配置nginx

配置Nginx 为我们的Django应用创建一个配置文件/etc/nginx/sites-available/alpfaceblog.conf

sudo vim alpfaceblog.conf

本文记录Ubuntu 16.04 上使用Nginx、 Gunicorn、supervisor 部署django项目

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-07/132889.htm

GRANT privileges ON databasename.tablename TO 'username'@'host';

5.django for QA进阶

在测试/质量保证过程中,常常会用到基于web的任务托盘,来支撑持续集成之类的工作。当具体需求需要对大路货jekins进行深度定制时,可以考虑改用django来做任务托盘,可扩展性要强得多,对python也更友好。

1.并发

manage.py是for debug的,性能不适合用于生产环境,因此一般基于其他容器来部署。这里举gunicorn为例,根据具体业务来决定子进程个数。然后gunicorn -w 12代表建立一个12个子进程的进程池。

现代web容器都是自带排队的,建立子进程池是for 长效任务需要较长时间独占进程的情况。

2.长效任务

在任务托盘的深度定制中,很可能某个任务是要长时间运行后输出结果的。在托盘模型中,对任务的管理需要是反馈式的,且各个任务的代码完全异构,并不方便跟一般的PC脚本一样做多进程交互。

因此service上可以直接不做多进程/线程,直接在一个viess.py的接口响应里,调用一个长效任务,多个任务多次请求即可。

但是这样做会触碰到gunicorn的timeout瓶颈,导致任务中断。这时需要借助eventlet插件,来协助处理子进程阻塞的情况。

安装eventlet:sudo easy_install eventlet

部署时加参数-k ‘eventlet’

3.时间

django有个非常微弱的小坑,就是有独立的时区,并不和server时区进行同步。所以需要在setting里面手工设置一下:

TIME_ZONE = ‘Asia/Shanghai’

nginx遇见的问题

1.最近在访问部分页面时,速度经常非常慢,导致报502 Bad Gateway错误
解决方法:
查看nginx的错误日志,我是配置在error_log /var/log/nginx/django_error.log;

日志中我发现了两个问题,第一个问题:

ubuntu@ip-172-31-17-237:/var/log/nginx$ cat django_error.log
2018/02/24 09:10:43 [error] 1132#1132: *72 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 66.249.64.22, server: www.alpface.com, request: "GET /article/2018/1/20/1.html HTTP/1.1", upstream: "http://unix:/var/www/Blog/run/gunicorn.sock/article/2018/1/20/1.html", host: "www.alpface.net"
2018/02/24 09:22:42 [error] 1132#1132: *87 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 222.249.170.75, server: www.alpface.com, request: "POST /admin/blog/article/add/ HTTP/1.1", upstream: "http://unix:/var/www/Blog/run/gunicorn.sock/admin/blog/article/add/", host: "alpface.com", referrer: "http://alpface.com/admin/blog/article/add/"

通过网友的各种尝试,我决定试一试,最终解决了,解决方法:
这是由于,NGINX反向代理的超时报错:

ubuntu@ip-172-31-17-237:/var/log/nginx$ cd /etc/nginx/sites-available/
ubuntu@ip-172-31-17-237:/etc/nginx/sites-available$ sudo vi alpfaceblog.conf 

在网站的配置文件中添加以下,并重启nginx

server {
listen 80;
server_name localhost;

    large_client_header_buffers 4 16k;  
    client_max_body_size 300m;  
    client_body_buffer_size 128k;  
    proxy_connect_timeout 600;  
    proxy_read_timeout 600;  
    proxy_send_timeout 600;  
    proxy_buffer_size 64k;  
    proxy_buffers   4 32k;  
    proxy_busy_buffers_size 64k;  
    proxy_temp_file_write_size 64k;  

    #.............................  
}  

重启:`sudo /etc/init.d/nginx restart`

第二个问题:
查看错误日志可以看到:`/var/www/Blog/media//`, media后面多了一个/, 这是由于nginx配置文件中的资源文件路径写错了导致的,修改下我的配置文件,重启nginx解决;

ubuntu@ip-172-31-17-237:/var/log/nginx$ cat django_error.log
2018/03/05 06:44:04 [error] 3493#3493: *1 upstream prematurely closed connection while reading response header from upstream, client: 222.249.170.75, server: localhost, request: "GET /article/2018/2/28/38.html HTTP/1.1", upstream: "http://unix:/var/www/Blog/run/gunicorn.sock:/article/2018/2/28/38.html", host: "www.alpface.com", referrer: "http://www.alpface.com/login/?next=/article/2018/2/28/38.html"
2018/03/05 06:51:16 [error] 3493#3493: *33 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/article/edit/?aid=32"
2018/03/05 06:51:26 [error] 3493#3493: *32 open() "/var/www/Blog/collectedstatic//blog/img/favicon.ico" failed (2: No such file or directory), client: 222.249.170.75, server: localhost, request: "GET /static/blog/img/favicon.ico HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/article/edit/?aid=32"
2018/03/05 06:56:05 [error] 3493#3493: *39 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/article/list/"
2018/03/05 06:56:09 [error] 3493#3493: *41 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/message/comment/"
2018/03/05 06:56:11 [error] 3493#3493: *41 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/message/os/"
2018/03/05 06:56:12 [error] 3493#3493: *41 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/message/comment/"
2018/03/05 06:56:15 [error] 3493#3493: *39 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/visitor/"
2018/03/05 06:56:18 [error] 3493#3493: *41 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/link/"
2018/03/05 06:56:23 [error] 3493#3493: *41 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/profile/"
2018/03/05 06:56:37 [error] 3493#3493: *41 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/profile/"
2018/03/05 06:56:40 [error] 3493#3493: *41 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/profile/"
2018/03/05 06:56:41 [error] 3493#3493: *39 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/link/"
2018/03/05 06:56:43 [error] 3493#3493: *39 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/profile/"
2018/03/05 06:56:45 [error] 3493#3493: *39 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "www.alpface.com", referrer: "http://www.alpface.com/admin/article/add/"
2018/03/05 06:56:52 [error] 3493#3493: *39 directory index of "/var/www/Blog/media//" is forbidden, client: 222.249.170.75, server: localhost, request: "GET /media/ HTTP/1.1", host: "澳门新濠3559,www.alpface.com", referrer: "http://www.alpface.com/admin/"

##### 执行数据库迁移时遇见的问题
1. 當修改或新增model後, 執行python manage.py makemigrations,未生成遷移:
解決方法:
刪除每個app文件下migrations文件中除了__init__.py的所有文件,然後再執行`python manage.py makemigrations`重新生成遷移

2. 數據庫遷移時遇見的問題:
錯誤信息:

django.db.utils.InternalError: (1054, "Unknown column 'name' in 'django_content_type'")

解決方法:
在数据库中手动添加没有创建的字段

alter table django_content_type add column name varchar(10)

3. 遷移數據庫python manage.py migrate時出錯:

django.db.utils.InternalError: (1050, "Table 'auth_permission' already exists")

解決方法:

python manage.py migrate --fake

但是此種方法會忽略一些錯誤,導致最終還是不能解決我們的遷移的問題


總結:
我的blog項目是在我的本地電腦ubuntu系統上開發並測試的,然後提交到github上,最後部署到亞馬遜服務器時,通過git命令clone到服務器上;
期間我在本地修改或創建了一些model,這時我在本地生成遷移和遷移時都沒有,但是在服務端遷移總是報錯,導致遷移失敗;
原因:在網上查找各種資料最終都沒有解決,最後我發覺項目的.gitignore中忽略了migrations文件,而每次改變model或新增model時,都會生成一個000n_.py文件,每次改變n都會加1,
此時我的數據庫也會在遷移時發生改變,而當我在服務器執行遷移時,服務器端沒有migrations文件,每次遷移都會重新生成,那麼和本地執行時機不同,所以會需要每次執行遷移時,會根據migrations執行的結果也不同;
解決方法:當然我們可以在gitignore中取消這些忽略文件, 另外當我們在服務器段執行遷移遇到文件時,我們可以把本地的0001_initial.py中的復制到服務端對應的這個文件再執行`python manage.py makemigrations`和`python manage.py migrate`

生产环境的KVM宿主机越来越多,需要对宿主机的状态进行调控。这里用webvirtmgr进行管理。图形化的WEB,让人能更方便的查看kvm 宿主机的情况和操作

创建MYSQL 用户

django最麻烦的地方,反而是部署,下面详细聊聊。

本文记录Ubuntu 16.04 上使用Nginx、 Gunicorn、supervisor 部署django项目

KVM WEB管理工具webvirtmgr安装和使用

授权

2.web容器

用户访问网站的行为,实际上是从服务器取得一个html文本,然后在本地浏览器进行解析。这些文本文件,就存放在服务端的web容器中,等待被用户请求。然而现代的网站,体量都很大,数据量巨大,且应用场景也多,安全性隐患也多,因此不可能全都使用静态文件来存储。现在仍然活着的web容器,都是支持cgi族协议的,也就是可以通过server脚本,实现网页动态化。

比较流行的web容器,有:apache,nginx,IIS等。虽然都是通用web容器,但是设计之初的区别,导致各自的应用场景不同。对wsgi最友好的是nginx,所以django最简便的部署方式就是做nginx映射。

安装并配置Supervisor

Superviosr是一个进程监管的工具。简而言之,Superviosr可以保证你的程序在服务器开机时自动启动以及程序意外终止时重新启动。

  • 安装
sudo apt-get install supervisor
  • 配置

supervisor的配置文件默认从/etc/supervisor/conf.d中读取

cd /etc/supervisor/conf.d

创建并编辑一个supervisor的配置文件

sudo vim alpfaceblog.conf 

添加下面内容,注意路径需要根据实际情况替换

[program:DjangoBlog]
command = /var/www/Blog/bin/django_start
user = root
autostart=true
autorestart=true

redirect_stderr = true
stdout_logfile = /root/logs/blog/robot.log
stderr_logfile=/root/logs/blog/err.log  

手动创建日志目录:

mkdir -p /root/logs/blog

上面一步我们使用了django_start,这里我们在项目的bin目录下创建下它, 路径需要根据实际情况替换:

sudo vim django_start

#!/bin/bash

NAME="DjangoBlog" # Name of the application
DJANGODIR=/var/www/Blog # Django project directory
SOCKFILE=/var/www/Blog/run/gunicorn.sock # we will communicte using this unix socket
USER=root # the user to run as
GROUP=root # the group to run as
NUM_WORKERS=3 # how many worker processes should Gunicorn spawn
DJANGO_SETTINGS_MODULE=DjangoBlog.settings # which settings file should Django use
DJANGO_WSGI_MODULE=DjangoBlog.wsgi # WSGI module name

echo "Starting $NAME as `whoami`"

# Activate the virtual environment
cd $DJANGODIR
source /home/parallels/.virtualenvs/alpfaceblog/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH

# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

# Start your Django Unicorn
# Programs meant to be run under supervisor should not daemonize themselves (do not use --daemon)
exec /home/parallels/.virtualenvs/alpfaceblog/bin/gunicorn ${DJANGO_WSGI_MODULE}:application 
--name $NAME 
--workers $NUM_WORKERS 
--user=$USER --group=$GROUP 
--bind=unix:$SOCKFILE 
--log-level=debug 
--log-file=-

通过supervisorctl工具来启用这些设置:

sudo supervisorctl update
sudo supervisorctl reload  

这里我遇到了启动错误信息:

pkg_resources.DistributionNotFound: The 'supervisor==3.2.0' distribution was

解决方法:
这是由于我把ubuntu的python默认环境改成3.5的了,其实再改回2.7就好了

切换Python版本
sudo update-alternatives --install /usr/bin/python python /usr/bin/python2 200
sudo update-alternatives --install /usr/bin/python python /usr/bin/python3 100

[摘要:临盆情况的KVM宿主机愈来愈多,须要对宿主机的状况举行调控。那里用webvirtmgr举行治理。图形化的WEB,让人能更轻易的检察kvm 宿主机的环境战操纵 1 装置支撑的硬件源 yum -y installhttp]

查看,修改数据库编码

Django是python web框架中,最popular的一个,关于model/view/controller/模版等,各种教程非常多,现用现查即可,推荐:http://www.ziqiangxuetang.com/django/django-tutorial.html

安装配置gunicorn

  • 首先切换到项目的虚拟环境
workon alpfaceblog
  • 在虚拟环境中安装gunicorn
pip install django gunicorn
  • 把 gunicorn 加入项目settings.py中的 INSTALLED_APPS
INSTALLED_APPS = (
    # ...
    'gunicorn',
)
  • 测试gunicorn是否可以正常工作
cd /var/www/Blog
sudo gunicorn -b 0.0.0.0:8888 --worker-class=gevent DjangoBlog.wsgi:application
  • 配置生产环境下的gunicorn
    创建一个bash脚本用于快速启动gunicorn的
    在项目目录下创建一个文件夹bin,然后创建gunicorn_start文件
sudo vim  gunicorn_start

添加以下内容,注意路径需要根据实际情况替换

#!/bin/bash

NAME="DjangoBlog" # 项目的名称
DJANGODIR=/var/www/Blog # 项目所在的目录
SOCKFILE=/var/www/Blog/run/gunicorn.sock # 启动gunicorn.sock使用UNIX套接字
USER=root # the user to run as
GROUP=root # the group to run as
NUM_WORKERS=3 # how many worker processes should Gunicorn spawn
DJANGO_SETTINGS_MODULE=DjangoBlog.settings # which settings file should Django use
DJANGO_WSGI_MODULE=DjangoBlog.wsgi # WSGI module name

echo "Starting $NAME as `whoami`"

# 启动虚拟环境的路径
cd $DJANGODIR
source /home/parallels/.virtualenvs/alpfaceblog/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH

# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

# Start your Django Unicorn
# gunicorn 安装在虚拟环境下的完整路径
exec /home/parallels/.virtualenvs/alpfaceblog/bin/gunicorn ${DJANGO_WSGI_MODULE}:application 
--name $NAME 
--workers $NUM_WORKERS 
--user=$USER --group=$GROUP 
--bind=unix:$SOCKFILE 
--log-level=debug 
--log-file=-

添加可执行权限: sudo chmod u+x bin/gunicorn_start
启动gunicorn

 ./bin/gunicorn_start

GRANT ALL ON `discuz`.* TO 'discuz'@'localhost';

创建数据库

登录mysql创建一个数据库,这里创建一个名称为blog数据库:

mysql -uroot -p

create database blog charset=utf8;

配置DjangoBlog/setting.py 中数据库 相关配置,如下所示:

     DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'blog',
            'USER': 'root',
            'PASSWORD': 'root',
            'HOST': 'host',
            'PORT': 3306,
        }
    }

查看用户权限:

安装配置gunicorn

  • 首先切换到项目的虚拟环境
workon alpfaceblog
  • 创建数据库
python manage.py makemigrations
python manage.py migrate
  • 创建超级用户
python manage.py createsuperuser
  • 收集静态文件
python manage.py collectstatic --noinput
python manage.py compress --force
  • 在虚拟环境中安装gunicorn
pip install django gunicorn
  • 把 gunicorn 加入项目settings.py中的 INSTALLED_APPS
INSTALLED_APPS = (
    # ...
    'gunicorn',
)
  • 测试gunicorn是否可以正常工作
cd /var/www/Blog
sudo gunicorn -b 0.0.0.0:8888 --worker-class=gevent DjangoBlog.wsgi:application
  • 配置生产环境下的gunicorn
    创建一个bash脚本用于快速启动gunicorn的
    在项目目录下创建一个文件夹bin,然后创建gunicorn_start文件
sudo vim  gunicorn_start

添加以下内容,注意路径需要根据实际情况替换

#!/bin/bash

NAME="DjangoBlog" # 项目的名称
DJANGODIR=/var/www/Blog # 项目所在的目录
SOCKFILE=/var/www/Blog/run/gunicorn.sock # 启动gunicorn.sock使用UNIX套接字
USER=root # the user to run as
GROUP=root # the group to run as
NUM_WORKERS=3 # how many worker processes should Gunicorn spawn
DJANGO_SETTINGS_MODULE=DjangoBlog.settings # which settings file should Django use
DJANGO_WSGI_MODULE=DjangoBlog.wsgi # WSGI module name

echo "Starting $NAME as `whoami`"

# 启动虚拟环境的路径
cd $DJANGODIR
source /home/parallels/.virtualenvs/alpfaceblog/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH

# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

# Start your Django Unicorn
# gunicorn 安装在虚拟环境下的完整路径
exec /home/parallels/.virtualenvs/alpfaceblog/bin/gunicorn ${DJANGO_WSGI_MODULE}:application 
--name $NAME 
--workers $NUM_WORKERS 
--user=$USER --group=$GROUP 
--bind=unix:$SOCKFILE 
--log-level=debug 
--log-file=-

添加可执行权限: sudo chmod u+x bin/gunicorn_start
启动gunicorn

 ./bin/gunicorn_start

nginx配置

Django文件的路径 最好是放在 /var/www/ 目录下,否则访问静态文件可能因为权限问题出现 403 forbidden error 错误,可以使用root账号来减小出现这种错误的可能。参考链接 

nginx配置文件的路径:

/etc/nginx/sites-available/ : 先把配置文件放在这里,编辑好之后,链接到目录 /etc/nginx/sites-enable/

简单的配置文件如下:

server 

{

    listen 80;

    location /static/ {

        alias /var/www/static/;  # 静态文件目录


    }

    location / {

        proxy_pass http://127.0.0.1:8999;

    }

}

不出意外应该是可以在浏览器端(访问地址: x.x.x.x)看到完整的页面了。另外要特别注意服务器开放的端口号有哪些。比如阿里云默认开放的端口号为 3389,需要自行设置一下,开放相应端口号,以免出现无法访问的问题。

 

准备工作:

  • 创建一个django项目
  • 创建一个python虚拟环境
  • 激活虚拟环境
    这里跳过准备工作,假设我已经有了一个项目DjangoBlog和一个虚拟环境alpfaceblog

Drop database db_name;

問題:

 

安装并配置nginx

  • 安装nginx
sudo apt-get install nginx

ubantu安装完Nginx后,文件结构大致为:
  所有的配置文件都在 /etc/nginx下;
  启动程序文件在 /usr/sbin/nginx下;
  日志文件在 /var/log/nginx/下,分别是access.log和error.log;
  并且在 /etc/init.d下创建了启动脚本nginx。

sudo /etc/init.d/nginx start # 启动
sudo /etc/init.d/nginx stop # 停止
sudo /etc/init.d/nginx restart # 重启

  • 配置nginx

配置Nginx 为我们的Django应用创建一个配置文件/etc/nginx/sites-available/alpfaceblog.conf

sudo vim alpfaceblog.conf

添加以下内容

upstream my_server {
    server unix:/var/www/Blog/run/gunicorn.sock fail_timeout=0;
}

server {

    server_name localhost;

    upstream my_server {
    server unix:/var/www/Blog/run/gunicorn.sock fail_timeout=0;
}

server {
    listen 80;
    server_name localhost;

    large_client_header_buffers 4 16k;
    client_max_body_size 300m;
    client_body_buffer_size 128k;
    proxy_connect_timeout 600;
    proxy_read_timeout 600;
    proxy_send_timeout 600;
    proxy_buffer_size 64k;
    proxy_buffers   4 32k;
    proxy_busy_buffers_size 64k;
    proxy_temp_file_write_size 64k;

    root /var/www/Blog;

    keepalive_timeout 70;
    access_log /var/log/nginx/django_access.log;
    error_log /var/log/nginx/django_error.log;

    location /static {
          expires max;
          alias /var/www/Blog/collectedstatic/;
    }

    location /media  {
        alias /var/www/Blog/media/;
    }
    location / {
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        if (!-f $request_filename) {
            proxy_pass http://my_server;
            break;
        }
    }

}
    root /var/www/Blog;

    listen 80;

    keepalive_timeout 70;
    access_log /var/log/nginx/django_access.log;
    error_log /var/log/nginx/django_error.log;

    location /static/ {
          expires max;
          alias /var/www/Blog/collectedstatic/;
    }

    location / {
         proxy_set_header Host $host;
         proxy_set_header X-Real-IP $remote_addr;

         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;


        if (!-f $request_filename) {
            proxy_pass http://my_server;
            break;
        }
    }

}
  • 让nginx的配置文件生效
 sudo ln -s  /etc/nginx/sites-available/alpfaceblog.conf   /etc/nginx/sites-enabled/alpfaceblog.conf
  • 重启nginx服务器
sudo service nginx restart

登陆mysql数据库客户端 mysql -u root -h localhost -p,安装mysql时,根据提示设置root账户的密码,这里使用root账号登录

其中的privileges包括 select , delete , update 等权限,Django操作数据库需要全部的权限,可参考如下命令

创建数据库 utf-8 字符编码

alter database <数据库名> character set utf8;

show grants for username@'localhost';

CREATE USER 'user_name'@'localhost' IDENTIFIED BY 'password';

  1. 买云服务器,选择Ubuntu系统
  2. 设置ssh登陆, windows平台通过Putty登陆Ubuntu云服务器. [ ]
  3. 软件安装

    1. 系统软件升级和 数据库软件,服务区软件安装: Sudo apt-get update ,sudo apt-get upgrade ,sudo apt-get install mysql-server-5.7 , nignx ,python3-pip
    2. Python包安装,: pip3 install Django==1.10.5 gunicorn Django-crontab 等等 Django项目需要的python包文件
  4. Git 设置. Git用于将编写的源代码同步到服务器,这里也可以采用其他方式。只需要把编写的Django源代码传到服务器下即可。

  5. 安装 nginx , gunicorn 。Nginx 用作代理服务器 ; gunicorn 用作wsgi 服务器
  6. 配置nginx。 Nginx默认的安装目录在 /etc/nginx/.

    nginx配置文件的路径: `/etc/nginx/sites-available/` : 先把配置文件放在这里,编辑好之后,链接到目录 `/etc/nginx/sites-enable/`

    ngixn 配置文件内容:

        server{

         listen 80;

            server_name 127.0.0.1; #访问django项目的网站

            access_log /var/www/Django_project /log/nginx.access.log;#访问日志

            error_log /var/www/ Django_project /log/nginx.error.log;#错误日志    

            location /static/ {

         root /var/www/ Django_project /;

                expires 30d;

         }

            location /media/ {

         alias /var/www/ Django_project /uploads/; #Django 项目接受上传文件的目录

                expires 30d;

         }

         location / {

         #动态请求交给gunicorn,8087端口就是gunicorn用的端口

                proxy_pass ;            

                proxy_set_header Host $host;

                proxy_set_header X-Real-IP $remote_addr;

                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

         }

        }

  7. 启动django 工程的服务,在Django_project 工程目录下执行: gunicorn -t 120 -w 2 -b 127.0.0.1:8087 Django_project.wsgi 。 Django的setting.py中要将服务器IP地址添加到ALLOWED_HOSTS。

  8. 如果没有问题的,现在可以在客户端浏览器中输入服务器IP地址就能看到完整的页面了

     

     

    附: Mysql数据库相关命令

根据setting.py文件的配置,创建数据库和相应的用户,需要的使用的命令如下:

CREATE DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

gunicorn 配置

gunicorn 可简单配置为

gunicorn –b 0.0.0.0:8999 dj.wsgi

执行命令之后,可以在浏览器访问页面,访问地址: 服务器IP(x.x.x.x):8999,但是看不到静态文件(图片,CSS,JS等)。静态文件的路径需要在nginx中配置。

参考连接 

 

 

编辑:编程 本文来源:这里使用root账号登录,KVM WEB管理工具webvirtmgr安

关键词:

  • 上一篇:没有了
  • 下一篇:没有了