小程序与MySQL数据库的交互_微信小程序与服务器的交互原理

1. 在linux服务器中配置nginx

简单说,微信小程序要正常运行起来,就要跟服务器进行数据交互,微信小程序服务器配置需要使用https安全域名,现在https证书可以免费申请,我用的是阿里云服务器,可以在阿里云上申请免费的https证书。

关于阿里云服务器配置nginx,请参见《在linux上通过nginx配置微信小程序服务器》。

pm2的安装使用

在nginx配置微信小程序服务器的文章里,我们安装的pm2,是一个能够启动运行nodejs项目的工具,内建负载均衡(使用 Node cluster 集群模块)。

安装很简单:

npm install -g pm2

安装完成之后输入:

pm2 start app.js

问题来了:

-bash: pm2: command not found

提示没有pm2这个命令,这是怎么回事呢?回头查看安装完成时的信息:

安装命令执行完成时候请注意终端输出内容

npm install -g pm2

/www/node-v8.2.1-linux-x64/bin/pm2 -> /www/node-v8.2.1-linux-x64/lib/node_modules/pm2/bin/pm2

/www/node-v8.2.1-linux-x64/bin/pm2-dev -> /www/node-v8.2.1-linux-x64/lib/node_modules/pm2/bin/pm2-dev

/www/node-v8.2.1-linux-x64/bin/pm2-docker -> /www/node-v8.2.1-linux-x64/lib/node_modules/pm2/bin/pm2-docker

/www/node-v8.2.1-linux-x64/bin/pm2-runtime -> /www/node-v8.2.1-linux-x64/lib/node_modules/pm2/bin/pm2-runtime

第一行箭头后面部分是/www/node-v8.2.1-linux-x64/lib/node_modules/pm2/bin/pm2,是pm2的安装目录,显然pm2默认目录不是全局的,下面设置pm2的安装目录软连接到全局下:

ln -s /www/node-v8.2.1-linux-x64/lib/node_modules/pm2/bin/pm2 /usr/local/bin

pm2设置为全局,启动一个项目:

pm2 start app.js

[PM2] Spawning PM2 daemon with pm2_home=/root/.pm2

[PM2] PM2 Successfully daemonized

[PM2] Starting /data/release/weapp/app.js in fork_mode (1 instance)

[PM2] Done.

┌──────────┬────┬─────────┬──────┬───────┬────────┬─────────┬────────┬─────┬──────────┬──────┬──────────┐

│ App name │ id │ version │ mode │ pid │ status │ restart │ uptime │ cpu │ mem │ user │ watching │

├──────────┼────┼─────────┼──────┼───────┼────────┼─────────┼────────┼─────┼──────────┼──────┼──────────┤

│ app │ 0 │ 1.0.0 │ fork │ 25378 │ online │ 0 │ 0s │ 0% │ 6.8 MB │ root │ disabled │

└──────────┴────┴─────────┴──────┴───────┴────────┴─────────┴────────┴─────┴──────────┴──────┴──────────┘

Use `pm2 show ` to get more details about an app

2. 微信小程序与服务器交互的流程及原理

官方demo服务端源码解析(了解即可,可略过)

查看小程序服务端的源码,不难发现,在服务器上配置数据库及预创建需连接的数据库是在

\server\tools\cAuth.sql中实现的:

SET NAMES utf8;

SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------

-- Table structure for `cSessionInfo`

-- ----------------------------

DROP TABLE IF EXISTS `cSessionInfo`;

CREATE TABLE `cSessionInfo` (

`open_id` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL,

`uuid` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL,

`skey` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL,

`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,

`last_visit_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,

`session_key` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL,

`user_info` varchar(2048)

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值