pomelo 环境

操作系统和node pomelo版本
ubuntu16.04 64bit
node 5.8.0 ($node -v)
npm 3.7.3 ($npm -v)
pomelo 1.2.3 ($pemelo –version)

npm安装的模块

注意模块的版本,比如
generic-pool 我的安装命令是

$npm install generic-pool@"<3.0" -g

因为generic-pool 3.0 在之前的基础上有很大的改变

pomelo建立项目

pomelo初始项目 需要选择websocket,socke.io(按照提示选择即可)

  • package.json

每个项目的根目录下面,一般都有一个package.json文件,定义了这个项目所需要的各种模块,以及项目的配置信息(比如名称、版本、许可证等元数据)。npm install命令根据这个配置文件,自动下载所需的模块,也就是配置项目所需的运行和开发环境。

例如game-server文件夹下的 package.json

{
    "name":"pemelopro1","version":"0.0.1","private":false,"dependencies":{ "pomelo":"1.2.3" } }

package.json 更多参考
http://javascript.ruanyifeng.com/nodejs/packagejson.html#

  • $sh npm-install.sh

pomelo 新建项目后,需要intall模块 即使用如下命令

sh npm-install.sh

可以查看npm-install.sh的内容,如下

cd ./game-server && npm install -d
echo '============ game-server npm installed ============'
cd ..
cd ./web-server && npm install -d
echo '============ web-server npm installed ============'

MysqL操作,注意自己的模块版本

game-server/app 目录下新建两个文件
dao/MysqL/dao-pool.js

var _poolModule = require('generic-pool');

/* * Create MysqL connection pool. */
var createMysqLPool = function(app) {
    var MysqLConfig = app.get('MysqL');
    var pool = _poolModule.Pool({
        name: 'MysqL',create: function(callback) {
            var MysqL = require('MysqL');
            var client = MysqL.createConnection({
                host: MysqLConfig.host,user: MysqLConfig.user,password: MysqLConfig.password,database: MysqLConfig.database
            });
            callback(null,client);
        },destroy: function(client) {
            client.end();
        },max: 10,idleTimeoutMillis : 30000,log : false
    });
    return pool;
};

exports.createMysqLPool = createMysqLPool;

dao/MysqL/MysqL.js

var sqlclient = module.exports;

var _pool;

var NND = {};

/* * Init sql connection pool * @param {Object} app The app for the server. */
NND.init = function(app){
    _pool = (require('./dao-pool')).createMysqLPool(app);
};

/** * Excute sql statement * @param {String} sql Statement The sql need to excute. * @param {Object} args The args for the sql. * @param {fuction} cb Callback function. * */
NND.query = function(sql,args,cb){
    _pool.acquire(function(err,client) {
        if (!!err) {
            console.error('[sqlqueryErr] '+err.stack);
            return;
        }
        client.query(sql,function(err,res) {
            _pool.release(client);
            cb(err,res);
        });
    });
};

/** * Close connection pool. */
NND.shutdown = function(){
    _pool.destroyAllNow();
};

/** * init database */
sqlclient.init = function(app) {
    if (!!_pool){
        return sqlclient;
    } else {
        NND.init(app);
        sqlclient.insert = NND.query;
        sqlclient.update = NND.query;
        sqlclient.delete = NND.query;
        sqlclient.query = NND.query;
        return sqlclient;
    }
};

/** * shutdown database */
sqlclient.shutdown = function(app) {
    NND.shutdown(app);
};

config 下写MysqL.json,数据库的连接,例如

{
    "development": { "host" : "127.0.0.1","port" : "3306","database" : "mydb","user" : "root","password" : "123456" },"production": { "host" : "127.0.0.1","password" : "123456" } }

修改 game-server下的app.js
添加三句话

app.loadConfig("MysqL",app.getBase() + "/config/MysqL.json"); // 添加配置

 var dbclient = require("./app/dao/MysqL/MysqL.js").init(app); // 初始化dbclient
  app.set("dbclient",dbclient);// dbclient 为外部数据库接口,app.get("dbclient") 来使用

完整的app.js

var pomelo = require('pomelo');

/** * Init app for client. */
var app = pomelo.createApp();
app.set('name','pemelopro1');

app.loadConfig("MysqL",app.getBase() + "/config/MysqL.json"); // 添加配置

// app configuration
app.configure('production|development','connector',function(){
  app.set('connectorConfig',{
      connector : pomelo.connectors.sioconnector,//websocket,htmlfile,xhr-polling,jsonp-polling,flashsocket
      transports : ['websocket'],heartbeats : true,closeTimeout : 60,heartbeatTimeout : 60,heartbeatInterval : 25
    });

  var dbclient = require("./app/dao/MysqL/MysqL.js").init(app); // 初始化dbclient
  app.set("dbclient",dbclient);// dbclient 为外部数据库接口,app.get("dbclient") 来使用

});

// start app
app.start();

process.on('uncaughtException',function (err) {
  console.error(' Caught exception: ' + err.stack);
});
  • 客户端代码修改
    很简单,就是请求时,传给服务端的数据修改了,变成了如下的数据
{username:'zhang',password:'123'}
<script type="text/javascript"> var pomelo = window.pomelo; var host = "127.0.0.1"; var port = "3010"; function show() { pomelo.init({ host: host,port: port,log: true },function() { pomelo.request("connector.entryHandler.entry",{username:'zhang',password:'123'},function(data) { alert(data.msg); }); }); } </script>
  • 服务端代码修改
    app/servers/connector/handler/entryHandler.js

直接修改Handler.prototype.entry 方法

Handler.prototype.entry = function(msg,session,next) {
  //next(null,{code: 200,msg: 'game server is ok.'});
    var username = msg.username;
    var password = msg.password
    var clientMsg ="";
    clientMsg += 'username:';
    clientMsg += username;
    clientMsg += 'password:';
    clientMsg += password;
        console.log(clientMsg);
    var sql = "insert into `User`(`username`,`password`) values(?,?);";
  var args = [username,password];

  var dbclient = this.app.get('dbclient');//获取全局MysqL client
    dbclient.query(sql,function (err,res) {//执行sql语句 函数insert和query等

            console.log("......................");
            console.log(err + " " + JSON.stringify(res));    
            console.log("......................");
            if (err) {
                    next(null,{code: 200,msg: 'db error'});
            }
            else {
                    next(null,msg: clientMsg });
            }
    });

  //next(null,result);
//next(null,msg: clientMsg});
};
  • 运行截图
  • 参考
    http://www.jb51.cc/article/p-aukifksn-bre.html

baidu搜出来的(基本都这样,否则需要github上看文档),写的不错,不过没有交代pomelo的环境,并且模块版本不一样,也是不行的,注意我上面方法的区别之处。

  • 建议安装node-dev模块
$ npm install node-dev -g

z在运行web-server时
原来的 node app.js 换成

$node-dev --debug app.js

当有js文件修改后 自动去重启nodejs进程,这样就不用每次ctrl+c终止,然后再重启了 而且不仅支持js文件,.json .node .coffee 文件格式都支持

ubuntu pomelo 新建项目,操作mysql数据库的更多相关文章

  1. HTML5 播放 RTSP 视频的实例代码

    目前大多数网络摄像头都是通过 RTSP 协议传输视频流的,但是 HTML 并不标准支持 RTSP 流。本文重点给大家介绍HTML5 播放 RTSP 视频的实例代码,需要的朋友参考下吧

  2. 利用Node实现HTML5离线存储的方法

    这篇文章主要介绍了利用Node实现HTML5离线存储的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. 详解如何通过H5(浏览器/WebView/其他)唤起本地app

    这篇文章主要介绍了详解如何通过H5(浏览器/WebView/其他)唤起本地app的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  4. H5混合开发app如何升级的方法

    本篇文章主要介绍了H5混合开发app如何升级的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  5. AmazeUI 折叠面板的实现代码

    这篇文章主要介绍了AmazeUI 折叠面板的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. HTML5手指下滑弹出负一屏阻止移动端浏览器内置下拉刷新功能的实现代码

    这篇文章主要介绍了HTML5手指下滑弹出负一屏阻止移动端浏览器内置下拉刷新功能的实现代码,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

  7. Html5 video标签视频的最佳实践

    这篇文章主要介绍了Html5 video标签视频的最佳实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  8. html5唤起app的方法

    这篇文章主要介绍了html5唤起app的方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  9. HTML5拍照和摄像机功能实战详解

    这篇文章主要介绍了HTML5拍照和摄像机功能实战详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. ios – 在没有iPhone6s或更新的情况下测试ARKit

    我在决定下载Xcode9之前.我想玩新的框架–ARKit.我知道要用ARKit运行app我需要一个带有A9芯片或更新版本的设备.不幸的是我有一个较旧的.我的问题是已经下载了新Xcode的人.在我的情况下有可能运行ARKit应用程序吗?那个或其他任何模拟器?任何想法或我将不得不购买新设备?解决方法任何iOS11设备都可以使用ARKit,但是具有高质量AR体验的全球跟踪功能需要使用A9或更高版本处理器的设备.使用iOS11测试版更新您的设备是必要的.

随机推荐

  1. crontab发送一个月份的电子邮件

    ubuntu14.04邮件服务器:Postfixroot收到来自crontab的十几封电子邮件.这些邮件包含PHP警告.>我已经解决了这些警告的原因.>我已修复每个cronjobs不发送电子邮件(输出发送到>/dev/null2>&1)>我删除了之前的所有电子邮件/var/mail/root/var/spool/mail/root但我仍然每小时收到十几封电子邮件.这些电子邮件来自cronjobs,

  2. 模拟两个ubuntu服务器计算机之间的慢速连接

    我想模拟以下场景:假设我有4台ubuntu服务器机器A,B,C和D.我想在机器A和机器C之间减少20%的网络带宽,在A和B之间减少10%.使用网络模拟/限制工具来做到这一点?

  3. ubuntu-12.04 – 如何在ubuntu 12.04中卸载从源安装的redis?

    我从源代码在Ubuntu12.04上安装了redis-server.但在某些时候它无法完全安装,最后一次makeinstallcmd失败.然后我刚刚通过apt包安装.现在我很困惑哪个安装正在运行哪个conf文件?实际上我想卸载/删除通过源安装的所有内容,只是想安装一个包.转到源代码树并尝试以下命令:如果这不起作用,您可以列出软件自行安装所需的步骤:

  4. ubuntu – “apt-get source”无法找到包但“apt-get install”和“apt-get cache”可以找到它

    我正在尝试下载软件包的源代码,但是当我运行时它无法找到.但是当我运行apt-cache搜索squid3时,它会找到它.它也适用于apt-getinstallsquid3.我使用的是Ubuntu11.04服务器,这是我的/etc/apt/sources.list我已经多次更新了.我尝试了很多不同的debs,并没有发现任何其他地方的错误.这里的问题是你的二进制包(deb)与你的源包(deb-src)不

  5. ubuntu – 有没有办法检测nginx何时完成正常关闭?

    &&touchrestarted),因为即使Nginx没有完成其关闭,touch命令也会立即执行.有没有好办法呢?这样的事情怎么样?因此,pgrep将查找任何Nginx进程,而while循环将让它坐在那里直到它们全部消失.你可以改变一些有用的东西,比如睡1;/etc/init.d/Nginx停止,以便它会休眠一秒钟,然后尝试使用init.d脚本停止Nginx.你也可以在某处放置一个计数器,这样你就可以在需要太长时间时发出轰击信号.

  6. ubuntu – 如何将所有外发电子邮件从postfix重定向到单个地址进行测试

    我正在为基于Web的应用程序设置测试服务器,该应用程序发送一些电子邮件通知.有时候测试是使用真实的客户数据进行的,因此我需要保证服务器在我们测试时无法向真实客户发送电子邮件.我想要的是配置postfix,以便它接收任何外发电子邮件并将其重定向到一个电子邮件地址,而不是传递到真正的目的地.我正在运行ubuntu服务器9.10.先感谢您设置本地用户以接收所有被困邮件:你需要在main.cf中添加:然后

  7. ubuntu – vagrant无法连接到虚拟框

    当我使用基本的Vagrantfile,只配置了两条线:我看到我的虚拟框打开,但是我的流氓日志多次显示此行直到超时:然后,超时后的一段时间,虚拟框框终于要求我登录,但是太久了!所以我用流氓/流氓记录.然后在我的物理机器上,如果我“流氓ssh”.没有事情发生,直到:怎么了?

  8. ubuntu – Nginx – 转发HTTP AUTH – 用户?

    我和Nginx和Jenkins有些麻烦.我尝试使用Nginx作为Jenkins实例的反向代理,使用HTTP基本身份验证.它到目前为止工作,但我不知道如何传递带有AUTH用户名的标头?}尝试将此指令添加到您的位置块

  9. Debian / Ubuntu – 删除后如何恢复/ var / cache / apt结构?

    我在ubuntu服务器上的空间不足,所以我做了这个命令以节省空间但是现在在尝试使用apt时,我会收到以下错误:等等显然我删除了一些目录结构.有没有办法做apt-getrebuild-var-tree或类似的?

  10. 检查ubuntu上安装的rubygems版本?

    如何查看我的ubuntu盒子上安装的rubygems版本?只是一个想法,列出已安装的软件包和grep为ruby或宝石或其他:)dpkg–get-selections

返回
顶部