文档章节

nginx+nodejs+mysql+memcached服务器后台架设centos6.5

c
 caiyezi
发布于 2016/11/08 20:23
字数 1747
阅读 8
收藏 0

需要的下面四个工具最好都采用yum安装,不要采用编译安装的方法,因为编译安装会导致某些依赖关系丢失。

nginx 作为HTTP和反向代理,处理静态页面,动态服务交由nodejs服务。

nodejs作为处理动态事件的服务器。

mysql是数据库。

memcahed是一个数据缓存系统,为mysql提供缓存功能

nginx+nodejs+mysql+memcached服务器后台架设centos6.5

首先你需要会使用linux的命令行操作,然后你至少需要简单理解js语言,还要熟悉mysql的基本操作

系统环境

系统环境是centos6.5,yum源可能需要更新,为了下载更快,可以更换国内源,taobao源或者163源,具体操作自行百度,这里我直接采用默认源。

使用下面的命令更新yum源

安装nginx

命令如下

安装nodejs

#安装epel源,否则yum上找不到nodejs
yum install http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
 
#安装nodejs 和 npm ,npm是nodejs的一个包管理器之类的软件。
yum install nodejs npm
 
#可以通过node -v 查看安装版本

express是nodejs的一个框架软件,很好很方便

安装mysql和memcached

安装mysql

#安装mysql
yum install mysql
yum install mysql-server
yum install mysql-devel
#mysql查看是否安装成功,进入mysql命令行输exit退出来

 使用mysql

mysqladmin -u root password root   #第一个root是root账户,第二个root是需要设置的密码,这里以“root”为例
mysql -u root -p       #以root用户登录mysql,会要求你输入密码,就输入刚刚设置的密码
#接下来就是基本的数据库操作,这里不再赘述

下面设置mysqld开机自启动,mysql的服务叫做mysqld

修改mysql远程连接:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;    //允许root用户以root密码远程连接
FLUSH   PRIVILEGES;        //刷新    

安装 memcached

#安装memcached
yum install memcached
#查看是否安装成功
memcached -h
#启动服务,默认会在11211端口启动,其他参数自行百度
service memcached start
#依然是设置开机自启
Chkconfig memcached on

架设服务器

环境配置好了,就可以架设服务器了

  1. 通过nginx建立nodejs服务器的反向代理
  2.  /etc/nginx/nginx.conf 这个文件就是调用conf.d中所有配置文件的配置文件,想添加自己的配置文件最好不要修改/nginx.conf和default.conf了,自己在conf.d中建立一个.conf文件
  3. cd /etc/nginx/conf.d 可以看到default.conf 这是默认的配置文件,可以通过修改它使nginx支持php等操作(默认支持php页面的代码被注释掉了,可以取消注释来建立)
  4.  /etc/nginx/conf.d 中建一个支持反向代理的.conf文件
  5. 接下来重启nginx服务 这时访问localhost:8080应该能看到localhost:3000的对应页面,如果出现502错误可以去/var/log/nginx里的err.log看看错误日志,比如权限问题,可以
     
  6. 以上基本的nodejs服务器和nginx代理服务器都算建立了,可以修改nginx.conf配置文件来确定哪些页面请求使用代理,哪些页面请求直接处理

附一篇nodejs通过memcached查询mysql的代码

//这个文件命名为sel.js,放在nodejs项目中的routes文件夹里
var express = require('express');
var URL = require("url");
var mysql = require("mysql");
var cache = require('memcached');
var router = express.Router();
 
router.get('/', function(req, res, next) {
    var memcached = new cache('localhost:11211');//新建cache连接
    memcached.get(URL.parse(req.url,true).query.name,function(err,rows){
        if(err) console.log(err);
        if (rows) {            //如果mmecache查到了
            res.send(rows);
            console.log("find in cache");    //显示查询结果
        } else{                    //否则新建mysql连接
                console.log("not find in cache");
                var con = mysql.createConnection({
                    host:'localhost',
                    user:'root',
                    password:'root',
                    database:'nodetest',
                    port:3306
                });
                con.connect();                //连接查询
                console.log("connect the mysql");
                con.query('select id from peo where name =?',[URL.parse(req.url,true).query.name], function(err0,rows1) {
                    if (err0) console.log(err0);
                    if (rows1 != "") {            //MYSQL中存在记录,将记录写回memcache,同时送给前台
                        console.log("find in mysql");
                        res.send(rows1);
                        memcached.set(URL.parse(req.url,true).query.name,rows1,10000,function(err0,rows1){
                            if(err0) console.log(err0);
                            console.log("save into cache");
                        });
                    } else{            //mysql中不存在记录,输出不存在
                        console.log("no record");
                        res.send("no record");
                    };        
                });
                con.end();
                console.log("end line of mysql");
            };
    memcached.end();
    console.log("end line of cache");
    });
});
module.exports = router;
//修改nodejs项目文件夹中的app.js文件
app.use(express.static(path.join(__dirname, 'public')));
 
app.use('/', routes);
app.use('/users', users);
app.use('/sel', require('./routes/sel'));  //这里是刚刚建立的sel路由文件,上下文对照代码自己找
 
 
// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');

声明: 本文由(fengneng)原创,转载请保留本文链接:http://www.yalewoo.com/nginx_nodejs_mysql_memcached_on_centos65.html

当然,你还可以在app.js中增加路由调用,然后在routes文件夹中写更多自己的模块,那就需要你深入的学习nodejs了。

本文转载自:http://www.cnblogs.com/vipzhou/p/4870179.html

共有 人打赏支持
c
粉丝 1
博文 108
码字总数 0
作品 0
西安
程序员
私信 提问
解决前后端分离的 CORS 跨域资源共享问题

后端架api服务器,架设的过程中要在服务器端设置开启 CORS 跨域资源共享,否则前后端只能架设在同一个服务器上的同一个端口上,没有办法做到真正的分离。 这方法是基于tomcat 下后台api的,其...

黑帽子
2015/10/19
827
0
centos6.5 架设Telnet服务

思路——由于生产环境无法接触到虚拟机或者控制台只允许通过远程连接而SSH方式是Linux平台的常用方式,一旦服务出问题停止就无法在管理服务器。 架设Telnet 管理服务 1 以下三个RPM包文件并上...

f61393569
2017/12/27
0
0
XBOX ONE游戏开发之登陆服务器(一)

XBOX ONE游戏开发之登陆服务器(一) XBOX LIVE是微软自已的认证服务器, 当我们开发游戏时,如果是联网游戏,需要自已架设单点登陆(SSO)服务器 这个需要微软提供Relying Party SDK 然后我讲...

付翔
2015/12/17
0
0
WordPress 3.7 Beta 2 发布

WordPress 3.7 Beta 2 发布了,该版本目前还在进一步开发中,不建议在真实环境下使用。该版本提升了后台自动更新的稳定性。修复了大约50个bug,包括 IE 11 下可视化编辑器的问题。 WordPres...

红薯
2013/10/11
573
2
论坛后台如何查看用户的密码?

论坛后台如何查看用户的密码?我只看到一串加密的字符串。我这个不是真的在网络上用的论坛,我是测试学习如何架设论坛,之前一张帖子有朋友叫我雇佣程序员,有的一上来就鄙视, 我想看用户密...

kdrhrg
2013/08/26
459
7

没有更多内容

加载失败,请刷新页面

加载更多

大数据教程(6.1)hadoop生态圈介绍及就业前景

1. HADOOP背景介绍 1.1、什么是HADOOP 1.HADOOP是apache旗下的一套开源软件平台 2.HADOOP提供的功能:利用服务器集群,根据用户的自定义业务逻辑,对海量数据进行分布式处理 3.HADOOP的核心组...

em_aaron
59分钟前
1
0
hadoop垃圾回收站

在生产生,hdfs回收站必须是开启的,一般设置为7天。 fs.trash.interval 为垃圾回收站保留时间,如果为0则禁用回收站功能。 fs.trash.checkpoint.interval 回收站检查点时间,一般设置为小于...

hnairdb
昨天
1
0
腾讯与Github的魔幻会面背后的故事…

10月22日,腾讯开源管理办公室有幸邀请到Github新晋CEO Nat Friedman,前来鹅厂参观交流。目前腾讯已经有近70个项目在Github上开源,共获得17w stars,世界排名11位。Github是腾讯开源的主阵...

腾讯开源
昨天
11
0
单例模式

单例模式(Singleton pattern)属于创建型设计模式。 保证一个类仅有一个实例,并提供一个访问它的全局访问点。 通常我们可以让一个全局变量使得一个对象被访问,但它不能防止你实例化多个对...

NinjaFrog
昨天
2
0
TypeScript基础入门之装饰器(三)

转载 TypeScript基础入门之装饰器(三) 继续上篇文章[TypeScript基础入门之装饰器(二)] 访问器装饰器 Accessor Decorator在访问器声明之前声明。 访问器装饰器应用于访问器的属性描述符,可用...

durban
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部