使用Nginx+CppCMS构建高效Web应用服务器
使用Nginx+CppCMS构建高效Web应用服务器
1:Why
当前,越来越多的网站使用了各种框架,大部分框架使用了脚本语言、半编译语言等。比如Java、Python、Php、C#.NET等。
这些框架大部分目标是解决快速开发、运行稳定。但是,缺点是:系统庞大、运行耗费资源多、运行效率低下、占用带宽大等。
本文提出一种新的Web应用解决方案,试图针对以上缺点进行优化。
完全使用静态页面,动态数据通过Ajax访问CppCMS提供的高效Rest服务由浏览器获取。
这样,
(1)CppCMS提供Rest服务。CppCMS使用编译后的机器码运行,
效率大大提高,平均性能大概是其他语言的10倍以上(http://cppcms.com/wikipp/en/page/benchmarks)
(2)使用Json传输数据。由客户端组织展示数据,降低服务器计算时间,降低带宽使用。否则,所有HTML数据都是在
服务端生成,服务端计算压力大,并且完整的HTML数据比直接传输数据要少得多。
(3)静态数据使用Nginx服务器,可以使用优秀的Nginx性能提供稳定的服务。
以下是比较传统方法和本文提出的方法:

2:How
本文以AWS EC2的Redhat Enterprise 为例描述整个操作过程:
(1)安装CppCMS+CppDB,安装过程CppCMS官网文档比较详细,不复杂,此不赘述。
(2)安装Mysql和Mysql client
(3)创建建数据库、表的脚本,使用脚本建立数据库、表
(4)程序(以CppCMS的例子程序forms为蓝本):
(4.1)插入数据
cppdb::pool::pointer my_pool = cppdb::pool::create("mysql:host=127.0.0.1;database=test;user=root;password='your password'");
cppdb::session sql(my_pool->open());
cppdb::statement stat;
stat = sql << "INSERT INTO t_test(test_name) VALUES(?) " << test_name;
stat.exec();
(4.2)检索数据
string query = "SELECT test_name FROM t_test order by id desc limit 5";
cppdb::result res = sql << query;
result = "<ol>";
while(res.next()) {
std::string test_name;
res >>test_name;
result += "<li>"+test_name+"</li>";
}
result += "</ol>";
(5)编译
g++ -Wall hello.cpp view.cpp -o hello -lcppcms -lbooster
(6)配置文件config.js
{
"service" : {
"api" : "http",
"port" : 8080
},
"http" : {
"script" : "/hello"
},
}
(7)运行
./hello -c config.js
(8)测试
http://ec2-35-164-231-255.us-west-2.compute.amazonaws.com:8080/hello/
此处注意,要去AWS EC2的控制台的安全组里设置8080端口开放,否则无法访问。
我们这里还开放Http 80端口,为Nginx监听端口。
(9)配合Nginx提供静态数据,并提供Rest服务的反向代理
(9.1)安装Nginx
(9.2)配置Nginx
server {
location / { #提供静态页面
root /data/www;
}
location /hello/ { #反向代理到CppCMS的Rest服务
proxy_pass http://localhost:8080/hello;
}
location ~ \.(gif|jpg|png)$ { #图像
root /data/images;
}
}
(9.3)使用新的配置文件启动Nginx后可以做如下测试:
(A)http://ec2-35-164-231-255.us-west-2.compute.amazonaws.com 这个导向了Nginx提供的静态页面
(B)http://ec2-35-164-231-255.us-west-2.compute.amazonaws.com/hello 这个导向了CppCMS提供的一个页面,可以输入名称,点击提交,把数据保存
(C)使用Ajax的目前还没有实现,等下次再说
使用Nginx+CppCMS构建高效Web应用服务器的更多相关文章
- 使用Nginx+CppCMS构建高效Web应用服务器(之二)
使用Nginx+CppCMS构建高效Web应用服务器(之二) 上一篇 使用Nginx+CppCMS构建高效Web应用服务器(之一) 大致介绍了网站的整体架构,实际上通过调用REST获取数据并没有实现. ...
- 使用Nginx+CppCMS构建高效Web应用服务器(之三)
使用Nginx+CppCMS构建高效Web应用服务器(之三) --充分利用服务器和客户端计算能力 欢迎测试,攻击:http://www.litelottery.com 网页右上角,选择博彩,演 ...
- OpenResty全功能Web应用服务器,打包了标准的 nginx 核心
OpenResty打包了标准的 nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项. 通过揉和众多设计良好的 nginx 模块,OpenResty 有效地把 nginx 服务器转变为一个 ...
- Nginx+Tomcat构建动、静分离WEB架构
一.简介 二.环境介绍 三.后端服务器安装配置 四.安装论坛 五.安装配置前端Nginx服务器 六.验证服务 一.Tomcat简介 Tomcat是Apache 软件基金会(Apache Softwar ...
- 【读书笔记】2016.12.10 《构建高性能Web站点》
本文地址 分享提纲: 1. 概述 2. 知识点 3. 待整理点 4. 参考文档 1. 概述 1.1)[该书信息] <构建高性能Web站点>: -- 百度百科 -- 本书目录: 第1章 绪论 ...
- OpenResty 是一个全功能的 Web 应用服务器
OpenResty (也称为 ngx_openresty)是一个全功能的 Web 应用服务器.它打包了标准的 Nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项. 通过众多进行良好设计的 ...
- 生产环境优雅的重启基于Nginx、Tornado的Web服务进程
Nginx是一个高效的Web服务器及代理服务器,Tornado是一个基于epoll的异步Web开发框架,通常使用Nginx做为Web服务器时,都会以FastCGI模式,而我们从开发.调试.运维的角度考 ...
- windows+nginx+iis+redis+Task.MainForm构建分布式架构 之 (nginx+iis构建服务集群)
本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...
- JSP之WEB服务器:Apache与Tomcat的区别 ,几种常见的web/应用服务器
注意:此为2009年的blog,注意时效性(针对常见服务器) APACHE是一个web服务器环境程序 启用他可以作为web服务器使用 不过只支持静态网页 如(asp,php,cgi,jsp)等 ...
随机推荐
- js动画(四)
终于到了最后了,这里要告一段落了,整了个js运动框架,咳咳咳,好冷 啊啊啊啊啊啊,这天气.妈的,工资怎么也不发,啊,说好的 人与人之间的信任呢?哎,气诶,不到150字啊,又是这个梗..怎么办?说些什么 ...
- HDU4738(割边)
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 深入了解GCD
首先提出一些问题: dispatch_async 函数如何实现,分发到主队列和全局队列有什么区别,一定会新建线程执行任务么? dispatch_sync 函数如何实现,为什么说 GCD 死锁是队列导致 ...
- 未来手机Alo即将问世!全息投影手机的新高峰!全息3d 网
文章来源:网络 编辑:大熊 [摘要]全息投影手机很早就开始炒,网络上的概念机也是丛出不穷,那么这款出自法国的概念机又是多么的奇葩?全息 3d 网带你一探究竟. 据外媒报道,在不久将来语 ...
- 蓝桥网试题 java 基础练习 十六进制转八进制
- -------------------------------------------------------------------------------------------------- ...
- gulp源码解析(三)—— 任务管理
上篇文章我们分别对 gulp 的 .src 和 .dest 两个主要接口做了分析,今天打算把剩下的面纱一起揭开 —— 解析 gulp.task 的源码,了解在 gulp4.0 中是如何管理.处理任务的 ...
- asp.net core mvc权限控制:权限控制介绍
在进行业务软件开发的时候,都会涉及到权限控制的问题,asp.net core mvc提供了相关特性. 在具体介绍使用方法前,我们需要先了解几个概念: 1,claim:英文翻译过来是声明的意思,一个cl ...
- React核心内容归纳总结
状态.属性.组件API.组件的生命周期 当react的状态改变时,自动执行this.render()方法更新组件ES6写React的时候,事件里不会自动绑定this,需要自己绑定,或者直接在const ...
- UITableView、UICollectionView行高/尺寸自适应
UITableView 我们都知道UITableView从iOS 8开始实现行高的自适应相对比较简单,首先必须设置estimatedRowHeight给出预估高度,设置rowHeight为UITabl ...
- CSS3的属性为什么要带前缀
使用过CSS3属性的同学都知道,CSS3属性都需要带各浏览器的前缀,甚至到现在,依然还有很多属性需要带前缀.这是为什么呢? 我的理解是,浏览器厂商以前就一直在实施CSS3,但它还未成为真正的标准.为此 ...