在阿里云服务器上配置CentOS+Nginx+Python+Flask环境


Posted in Python onJune 18, 2016

项目运行环境

阿里云(单核CPU, 1G内存, Ubuntu 14.04 x64 带宽1Mbps), 具体购买和ssh连接阿里云本文不做描述。

实用工具

首先进入阿里云后先要升级下apt-get, 并下载所需软件

sudo apt-get update
sudo apt-get install vim git wget tmux

我还会使用zsh和oh-my-zsh来替换bash

sudo apt-get install zsh

# 终端下打以下命令
wget --no-check-certificate https://github.com/robbyrussell/oh-my-zsh/raw/master/tools/install.sh -O - | sh

替换bash为zsh

chsh -s /bin/zsh

重新连接阿里云就可以看到效果, 具体主题可以根据自己喜好更改主目录下的.zshrc即可

安装python相关模块

使用python的pip包管理工具

sudo apt-get install python-setuptools
sudo apt-get install python-pip
sudo pip install python-virtualenv

在主目录下创建文件夹code并把所有项目放进这个目录里

mkdir code

# 使用virtualenv
vritualenv venv

# 开启virtualenv
source /venv/bin/activate

# 关闭virtualenv
deactivate

# 在开启virtualenv的状态下使用pip会使用venv中的pip,也就是所有模块都会安装到venv中
# 如果想要安装全局模块就使用sudo pip 

# 安装flask, 安装到venv中
pip install flask

# 两个是不同的, 安装到系统中
sudo pip install flask

使用Flask

现在我们已经安装了Flask, 现在我们写一个小的程序来运行一下。
这里我们在一次安装flask的相关模块,并把他们写入到requirements.txt这个文件中。

# 安装flask的相关模块
pip install -r requirements

# 创建一个manage.py文件, 用作管理我们的应用, 然后创建我们的一个应用。
touch manage.py

## 创建一个叫bamboo的应用
mkdir bamboo

## 创建一个应用的文件, 接下来我们要编辑这个文件了。
touch bamboo/__init__.py bamboo/app.py

项目目录结构是这样的

/root/code/
├── bamboo
│  ├── app.py
│  ├── config.py
│  ├── __init__.py
│  ├── static
│  ├── templates
│  └── views
├── gunicorn.conf
├── logs
│  ├── access.log
│  ├── error.log
│  ├── supervisord.log
│  ├── supervisor_err.log
│  └── supervisor_out.log
├── manage.py
├── requirements.txt
├── run.py
├── sweep.py
└── venv

编辑bamboo/app.py和bamboo/views/main.py

## app.py
from flask import Flask

def create_app():
  app = Flask(__name__)

  # do something

  register_blueprints(app)
  return app


# 用来注册视图的路由
def register_blueprints(app):
  from bamboo.views import main, error
  for i in (main, error):
    app.register_blueprint(i.bp)

## main.py
from flask import render_template, Blueprint

bp = Blueprint('main', __name__)


@bp.route('/')
@bp.route('/index')
def index():
  return '<h1>Hello, Bamboo!</h1>'

安装Gunicorn

Gunicorn是一个wsgi服务器, 我们将通过它来启动我们的web服务。

# 注意我们是通过pip来安装,所以该模块所有文件都是在venv里面
pip install gunicorn

可以进入目录vevn/bin下查看是否存在gunicorn命令

# 这里我们编辑下manage.py文件,具体文件路径请查看上文中的目录结构
## manage.py

from bamboo.app import create_app
from flask.ext.script import Manager, Server, Shell

app = create_app()
manager = Manager(app)

def make_shell_context():
  # 用于shell使用
  pass

manager.add_command('shell', Shell(make_context=make_shell_context))
manager.add_command('runserver', Server(
  use_debugger=True,
  use_reloader=True,
  host='127.0.0.1',
  port=5000
))

if __name__ == '__main__':
  manager.run()

运行一下manage.py

# 不适用gunicorn运行
python manage.py runserver

# 使用gunicorn 运行
# 这里需要注意一下, 冒号前面的是文件名也就是manage.py而后面的是应用的名称。我在这里载过跟头。因为服务器需要接受一个wsgi的应用而manager = Manager(app)不是一个wsgi应用所以报错
gunicorn manage:app

我们创建一个gunicorn配置文件gunicorn.conf并把他放到code目录下

## gunicorn.conf

workers=3
bind='127.0.0.1:5000'

安装Nginx

我们通过nginx来反向代理我们的服务。

# 首先下载一个nginx
sudo apt-get install nginx

我们可以访问我们的域名或IP地址,如果出现Nginx的提示就表示安装成功了。
nginx安装在/etc/nginx/目录下, 我们把项目的配置文件放到/etc/nginx/sites-available/

server{
  listen 80;
  server_name xxx.xxx.xxx.xxx;

  # nginx log信息, 需要创建logs目录
  access_log /root/code/logs/access.log
  error_log /root/code/logs/error.log

  location / {
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header HOST $host;
    proxy_redirect off;
    if (!-f $request_filename){
      proxy_pass http://127.0.0.1:5000;
      break;
    }
  }
}

需要创建一个软链接到/etc/nginx/sites-enabled/

# 这里bamoo只是文件名你也可以取自己的项目名称
ln -s /etc/nginx/sites-available/bamboo /etc/nginx/sites-enabled/bamboo

# 然后检查nginx有没有错误
nginx -t 

# 重新启动服务
service nginx restart
安装Supervisor

supervisor用来监控进程,并在进程挂掉的时候自动重启它。

# 这里需要把它安装到系统中
sudo pip install supervisor

# 生成配置文件
sudo echo_supervisord_conf > /etc/supervisord.conf
# 编辑/etc/supervisord.conf,并在最后一行加入一下字段
# 这样配置文件会将/etc/supervisor/conf.d下所有.conf结尾的都会导入进来
[include]
files = /etc/supervisor/conf.d/*.conf

# 在创建一个配置文件到/etc/supervisor/conf.d/bamboo.conf
[program:bamboo]
command=/root/code/venv/bin/gunicorn manage:app -c /root/code/gunicorn.conf
directory=/root/code/
user=root
autostart=true
autorestart=true
stdout_logfile=/root/code/logs/supervisor_out.log
stderr_logfile=/root/code/logs/supervisor_err.log

通过supervisorctl工具用来管理supervisor维护的进程

# reread来检测修改的配置内容, update来更新
# 这样就可以看到bamboo的process启动了
supervisorctl reread
supervisorctl update 

# 也可以通过supervisorctl status 查看所有的项目进程
bamboo              RUNNING  pid 12928, uptime 2:13:05

这样我们的web服务已经启动起来了。

Python 相关文章推荐
python在windows下实现备份程序实例
Jul 04 Python
python编程通过蒙特卡洛法计算定积分详解
Dec 13 Python
python+matplotlib实现动态绘制图片实例代码(交互式绘图)
Jan 20 Python
python 读取DICOM头文件的实例
May 07 Python
详解Django 中是否使用时区的区别
Jun 14 Python
python 使用 requests 模块发送http请求 的方法
Dec 09 Python
python try 异常处理(史上最全)
Mar 07 Python
详解python的argpare和click模块小结
Mar 31 Python
python 发送get请求接口详解
Nov 17 Python
Python+unittest+DDT实现数据驱动测试
Nov 30 Python
Python3使用tesserocr识别字母数字验证码的实现
Jan 29 Python
python使用openpyxl库读写Excel表格的方法(增删改查操作)
May 02 Python
Python中使用装饰器来优化尾递归的示例
Jun 18 #Python
举例讲解Python面向对象编程中类的继承
Jun 17 #Python
浅谈python为什么不需要三目运算符和switch
Jun 17 #Python
python运行时间的几种方法
Jun 17 #Python
从局部变量和全局变量开始全面解析Python中变量的作用域
Jun 16 #Python
实例讲解Python中global语句下全局变量的值的修改
Jun 16 #Python
最大K个数问题的Python版解法总结
Jun 16 #Python
You might like
无数据库的详细域名查询程序PHP版(5)
2006/10/09 PHP
非常精妙的PHP递归调用与静态变量使用
2012/12/16 PHP
学习php设计模式 php实现状态模式
2015/12/07 PHP
javascript 有用的脚本函数
2009/05/07 Javascript
jquery $.fn $.fx是什么意思有什么用
2013/11/04 Javascript
jquery退出each循环的写法
2014/02/26 Javascript
js创建一个input数组并绑定click事件的方法
2014/06/12 Javascript
jQuery实现鼠标单击网页文字后在文本框显示的方法
2015/05/06 Javascript
jQuery基于json与cookie实现购物车的方法
2016/04/15 Javascript
详解vue.js2.0父组件点击触发子组件方法
2017/05/10 Javascript
JavaScript正则表达式校验与递归函数实际应用实例解析
2017/08/04 Javascript
vue用递归组件写树形控件的实例代码
2018/07/19 Javascript
微信小程序使用gitee进行版本管理
2018/09/20 Javascript
AngularJS 多指令Scope问题的解决
2018/10/25 Javascript
小程序云开发获取不到数据库记录的解决方法
2019/05/18 Javascript
微信小程序中button去除默认的边框实例代码
2019/08/01 Javascript
微信小程序绑定手机号获取验证码功能
2019/10/22 Javascript
Vue的Eslint配置文件eslintrc.js说明与规则介绍
2020/02/03 Javascript
解决vue刷新页面以后丢失store的数据问题
2020/08/11 Javascript
常用python数据类型转换函数总结
2014/03/11 Python
利用Pandas 创建空的DataFrame方法
2018/04/08 Python
Python用61行代码实现图片像素化的示例代码
2018/12/10 Python
Python中print函数简单使用总结
2019/08/05 Python
PyQt5通信机制 信号与槽详解
2019/08/07 Python
python写入数据到csv或xlsx文件的3种方法
2019/08/23 Python
flask/django 动态查询表结构相同表名不同数据的Model实现方法
2019/08/29 Python
Anaconda3+tensorflow2.0.0+PyCharm安装与环境搭建(图文)
2020/02/18 Python
python实现IOU计算案例
2020/04/12 Python
Pycharm Plugins加载失败问题解决方案
2020/11/28 Python
最新大学职业规划书范文
2013/12/30 职场文书
2014年销售员工作总结
2014/12/01 职场文书
2015年学校政教处工作总结
2015/05/26 职场文书
2015初中教导处工作总结
2015/07/21 职场文书
Vue.js 带下拉选项的输入框(Textbox with Dropdown)组件
2021/04/17 Vue.js
Windows Server 2016 配置 IIS 的详细步骤
2022/04/28 Servers