前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Ubuntu环境下Tornado环境部署

Ubuntu环境下Tornado环境部署

作者头像
NaOH
发布2018-05-29 13:15:52
1.2K0
发布2018-05-29 13:15:52
举报
文章被收录于专栏:写写代码吃吃瓜

这是之前在学tornado时记的一点小东西,但是在服务器上搭环境时其实还是很简单的(比起rails而言,手动斜眼笑) 但是安装过程中也遇到一些问题就记下来

安装

先安装python的pip,这个类似于ruby的gem,用于包管理和下载 然后用命令可以下载tornado

代码语言:javascript
复制
apt-get install python-pip
pip install tarnado

数据库配置

MYSQL

我之前用的是mysql,然后使用的ORM工具是sqlalchemy,当然首要的还是先安装mysql

但是安装前有一些必要的准备工作。就是装下面的包,使用apt-get install命令即可

代码语言:javascript
复制
libmysqld-dev
libmysqlclient-dev
python-dev

前两个包需要安装的原因是,通过apt-get install 安装的mysql没有mysql_config配置文件,会在后面要配置mysql时遇到问题 后一个是为了用来编译安装包 (安装顺序切勿不要混乱,因为之前这个地方我尝试过前两个包的安装顺序颠倒会有问题,我也不知道为什么,如果装了python-dev后运行python setup.py build还不行。可以重装libmysqlclient-dev)

下载mysql

代码语言:javascript
复制
wget http://sourceforge.net/projects/mysql-python/files/mysql-python/1.2.3/MySQL-python-1.2.3.tar.gz

解压

代码语言:javascript
复制
tar zxvf MySQL-python-1.2.3.tar.gz

安装

代码语言:javascript
复制
$ cd MySQL-python-1.2.3
$ python setup.py build
$ python setup.py install  //这里就是前面提到的运行python setup.py build可能会出问题,可以重装libmysqlclient-dev试试

如果遇到如下的错误

EnvironmentError: mysql_config not found

首先查找mysql_config的位置,使用下面的命令找到所在目录

代码语言:javascript
复制
find / -name mysql_config 

比如我的在

代码语言:javascript
复制
/usr/local/mysql/bin/mysql_config

再修改setup_posix.py文件,在26行:

代码语言:javascript
复制
mysql_config.path = “mysql_config” 

修改mysql_config的path为刚刚用find找到的路径,代码如下:

代码语言:javascript
复制
mysql_config.path = “/usr/local/mysql/bin/mysql_config

之后就可以使用tornado进行开发了

如果要向服务器传代码可以使用scp和服务器进行数据交换 具体操作是 scp filename root@XXX.XXX.XXX.XXX:~ 接下来按照提示输入密码,然后filename文件会被传至根目录下

部署方式

tornado一般是运行包含启动应用程序的main.py文件来运行webapp的,部署时我们需要使用

代码语言:javascript
复制
python main.py &

后面的&的意思是这个程序会以后台程序运行 如果想保持进程在ssh下线后还继续挂在服务器上,可以使用

代码语言:javascript
复制
nohup python main.py &

这样这个程序的log信息会输出到nohup.out文件中

关闭服务

如果这个程序在前台跑,那么只需要ctrl + c就可以关掉了,如果在后台则需要先查看进程的pid号 有一个查看活跃的联网程序端口占用的方法:

代码语言:javascript
复制
netstat -anp 

查看3000端口:

代码语言:javascript
复制
netstat -anp |grep 3000

会显示

代码语言:javascript
复制
Proto Recv-Q   Send-Q   Local Address           Foreign Address         State       PID/Program name
tcp        0        0   0.0.0.0:3000            0.0.0.0:*               LISTEN      12074/ruby

这里我在3000端口跑的是一个rails的进程,使用kill 12074可以杀掉这个进程

如果是tornado部署在这里可能会显示

代码语言:javascript
复制
tcp        0        0   0.0.0.0:3000            0.0.0.0:*               LISTEN      25239/python

但是有的时候使用这个命令由于自己进程比较多的话就很难找,可以使用

代码语言:javascript
复制
pgrep -l python

这个命令的作用是显示含有python关键字的进程的pid号,比如

代码语言:javascript
复制
25239 python

然后使用 kill 25239 命令就可以关闭这个进程了 pgrep的-l参数如果进程比较少,有时可以省略,其作用是显示进程名字,如果不加时结果就是

代码语言:javascript
复制
pgrep  python
25239 
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015年11月24日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装
  • 数据库配置
    • MYSQL
    • 部署方式
    • 关闭服务
    相关产品与服务
    云数据库 MySQL
    腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档