仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 636|回复: 10
打印 上一主题 下一主题

[学习教程] JAVA编程:利用Tornado+Nginx部署Django的一种实验仓酷云

[复制链接]
山那边是海 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-18 11:23:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
对于一个大型项目,如果用java来作,可能需要9个月,并且可能需要翻阅10本以上的书,但如果用ruby来作,3个月,3本书就足够了,而.net网页编程也不过3,4本书足以,这就是区别。Tornado是一个异步web框架和服务器,以是在开辟longpulling的chat之类使用十分的符合,可是实在自己也是一个高功能的http服务器,也能够作为一个WSGIServer。以是即便你的网站没有利用Tornado的框架,而是用了web.py大概是Django来开辟(傻瓜万岁),这个时分Tornado仍然能够用来减速你的网站。利用Tornado来取代fastCGI能够年夜幅进步功能,且能够承载的并发才能也有了成倍的进步(人人能够本人Profile,本文只先容假如做)。
良多人诟病Django,出格是利用Python的人,切实其实,python社区历来不短少框架,仅仅Python官方wiki上列出的出名Framework就数十种之多,作为一个全功效的框架,要兼容工具太多,功能丧失是很难制止的,成绩是丧失到甚么水平,我们可否针对本人使用特性往优化,而不是吠形吠声的回绝与小看大概本人造轮子,跟着瀑布流鼻祖http://pinterest.com/的兴起,而这个网站恰好是Django做的,今朝这个网站天天的自力访客凌驾1800万人,总数据凌驾400T,而总雇员只要12人。这就是Python和Django的临盆力。关于http://pinterest.com/利用Django的概况,能够参考这边:http://highscalability.com/blog/2012/5/21/pinterest-architecture-update-18-million-visitors-10x-growth.html
上面我们入手下手来先容怎样设置。这里我们假定你的一个用Django写的网站在一台Linux的服务器上康乐地着(ubuntuorCentOS,没试过在其他刊行版折腾过,windows?你在谈笑吧),跟着网站愈来愈红火,你更加感到服务器不胜重负。这个时分Tornado呈现了,他可让你再苟延残喘好几个月,勤俭一年夜把的银子往把妹.............回到正题。依据官网的保举部署体例,我们仍是接纳Nginx经由过程upstream来反向代办署理到N个Tornado的服务器实例上的部署体例。so
Setp1:安装supervisord
因为Tornado并没有本身供应Daemon的才能,以是我们必要用一个服务办理工具来办理Tornado的历程,supervisord是用Python完成的一款十分有用的历程办理工具。能够很便利的办理N过历程,且撑持历程分组。Supervisord能够经由过程sudoeasy_installsupervisor安装,固然也能够经由过程Supervisord官网下载后setup.pyinstall安装。
Step2:给Django的站点增添一个Tornado的服务器文件(好比serv.py)
创立一个文件Serv.py在Django站点的根目次(Django1.4中应当放到和urls.py统一级目次),内容以下:
importos
importsys
fromtornado.optionsimportoptions,define,parse_command_line
importdjango.core.handlers.wsgi
importtornado.httpserver
importtornado.ioloop
importtornado.web
importtornado.wsgi
_HERE=os.path.dirname(os.path.abspath(file))
sys.path.append(_HERE)
sys.path.append(os.path.join(_HERE,..))
sys.path.append(os.path.join(_HERE,../contrib))
os.environ[DJANGO_SETTINGS_MODULE]="settings"
defmain(port):
  1. wsgi_app=tornado.wsgi.WSGIContainer(django.core.handlers.wsgi.WSGIHandler())tornado_app=tornado.web.Application([(.*,tornado.web.FallbackHandler,dict(fallback=wsgi_app)),])server=tornado.httpserver.HTTPServer(tornado_app)server.listen(port)tornado.ioloop.IOLoop.instance().start()
复制代码
ifname==main:
  1. main(int(sys.argv[1]))
复制代码
我这里经由过程第一个参数来指定Tornado服务监听的端口。如许对照天真,这点我们在前面的步骤会用到。这个时分我们能够经由过程
pythonServ.py8000
这个命令来启动服务器
Step3:设置Supervisord
第一步安装的Supervisord还没有设置,以是我们必要先创立一个设置文件的榜样。在root权限下实行
echo_supervisord_conf>/etc/supervisord.conf
这个时分在/etc/创立了设置文件,用vim翻开这个文件,在设置文件的屁股前面加上以下这一段
[program:web]
command=python/var/www/site/Serv.py80%(process_num)02d
process_name=%(program_name)s_%(process_num)02d
umask=022
startsecs=0
stopwaitsecs=0
redirect_stderr=true
stdout_logfile=/tmp/codoon.log
numprocs=4
numprocs_start=1
这个设置会启动4个Tornado的服务历程分离监听8001,8002,8003,8004这四个端口
command这一行是要实行的命令,这里是用python/var/www/site/Serv.py端标语来启动Tornado的服务历程80%(process_num)02d的用处是经由过程历程编号来天生端标语。上面的process_name这个参数也会用到。这里要指定的文件名就是上一步我们创立谁人Serv.py文件
process_name是历程的名字,因为这里要启动4个历程,以是要用process_num来辨别
umask是程序实行的权限参数
startsecs这个参数是程序启动的守候工夫
stopwaitsecs这个参数是程序中断的守候工夫
redirect_stderr这个参数将毛病流重定向到std的流输入,如许能够省往一个日记文件的设置,固然也能够不必这个参数分隔设置日记文件
stdout_logfile这个参数是STD流输入日记文件的路径,Tornado会输入一切的哀求和毛病信息,经由过程这个能够一致做日记处置,分开甚么的,在程序里就只必要print到std流就好了。
numprocs这个参数指定了历程的数目,这里是4,标明要启动4个Tornado历程
numprocs_start这个参数指定了历程号的肇端编号,这里是1,如许后面的command和process_name里的%(process_num)02d部分就会在实行的时分被交换为01~05的字符串
设置修正完成后:wq保留加入,实行:
supervisorctlreload
从头加载设置后,这些历程就启动起来了
Step4:修正设置Nginx
起首找到在vhost目次里你的站点设置文件,翻开后,在头上增添upstream的内容
upstreamfrontends{
server127.0.0.1:8001;
server127.0.0.1:8002;
server127.0.0.1:8003;
server127.0.0.1:8004;
}
然后在Server设置节里找到
location/{这个设置节
之前是用的FastCGI,以是内里的设置多是如许子的
hostandporttofastcgiserver

fastcgi_pass127.0.0.1:8081;

fastcgi_paramPATH_INFO$fastcgi_script_name;

fastcgi_paramREQUEST_METHOD$request_method;

fastcgi_paramQUERY_STRING$query_string;

fastcgi_paramCONTENT_TYPE$content_type;

fastcgi_paramCONTENT_LENGTH$content_length;

fastcgi_pass_headerAuthorization;

fastcgi_paramREMOTE_ADDR$remote_addr;

fastcgi_paramSERVER_PROTOCOL$server_protocol;

fastcgi_paramSERVER_PORT$server_port;

fastcgi_paramSERVER_NAME$server_name;

fastcgi_intercept_errorsoff;

把这些一切删失落,酿成了如许
location/{
}

C++编译的是本地码,优点是启动快,而且可以精确控制资源因此可以开发很高效的程序.缺点是编程麻烦,而且容易留下安全隐患.跨平台靠源代码在各个平台间分别编译(一处编写到处编译)
兰色精灵 该用户已被删除
沙发
发表于 2015-1-20 23:48:15 | 只看该作者
你可以去承接一些项目做了,一开始可能有些困难,可是你有技术积累,又考虑周全,接下项目来可以迅速作完,相信大家以后都会来找你的,所以Money就哗啦啦的。。。。。。
简单生活 该用户已被删除
板凳
发表于 2015-1-30 07:37:34 | 只看该作者
你可以去承接一些项目做了,一开始可能有些困难,可是你有技术积累,又考虑周全,接下项目来可以迅速作完,相信大家以后都会来找你的,所以Money就哗啦啦的。。。。。。
金色的骷髅 该用户已被删除
地板
发表于 2015-2-1 16:47:18 来自手机 | 只看该作者
至于JDBC,就不用我多说了,你如果用java编过存取数据库的程序,就应该很熟悉。还有,如果你要用Java编发送电子邮件的程序,你就得看看Javamail 了。
小妖女 该用户已被删除
5#
发表于 2015-2-2 09:48:12 | 只看该作者
你一定会高兴地说,哈哈,原来成为Java高手就这么简单啊!记得Tomjava也曾碰到过一个项目经理,号称Java很简单,只要三个月就可以学会。
山那边是海 该用户已被删除
6#
 楼主| 发表于 2015-2-6 21:53:25 | 只看该作者
是一种使用者不需花费很多时间学习的语言
小女巫 该用户已被删除
7#
发表于 2015-2-7 18:15:54 | 只看该作者
Java自面世后就非常流行,发展迅速,对C++语言形成了有力冲击。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于个人PC、数据中心、游戏控制台
乐观 该用户已被删除
8#
发表于 2015-3-1 22:17:53 | 只看该作者
其实说这种话的人就如当年小日本号称“三个月拿下中国”一样大言不惭。不是Tomjava泼你冷水,你现在只是学到了Java的骨架,却还没有学到Java的精髓。接下来你得研究设计模式了。
若相依 该用户已被删除
9#
发表于 2015-3-9 21:50:39 | 只看该作者
你可以去承接一些项目做了,一开始可能有些困难,可是你有技术积累,又考虑周全,接下项目来可以迅速作完,相信大家以后都会来找你的,所以Money就哗啦啦的。。。。。。
爱飞 该用户已被删除
10#
发表于 2015-3-17 01:49:36 | 只看该作者
那么我书也看了,程序也做了,别人问我的问题我都能解决了,是不是就成为高手了呢?当然没那么简单,这只是万里长征走完了第一步。不信?那你出去接一个项目,你知道怎么下手吗,你知道怎么设计吗,你知道怎么组织人员进行开发吗?你现在脑子里除了一些散乱的代码之外,可能再没有别的东西了吧!
第二个灵魂 该用户已被删除
11#
发表于 2015-3-23 12:28:14 | 只看该作者
象、泛型编程的特性,广泛应用于企业级Web应用开发和移动应用开发。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-9-28 19:23

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表