15分钟从零开始搭建支持10w+用户的生产环境(二)

上一篇文章,把这个架构的原由,和操做系统的选择进行了详细说明。html

原文地址:15分钟从零开始搭建支持10w+用户的生产环境(一)linux

2、数据库的选择

对于一个10W+用户的系统,数据库选择很重要。web

通常来讲,这个用户量,根据不一样的应用,会造成单表年度400W~4000W条的数据量。在这个数据量下,咱们须要相对大型的数据库。mongodb

可供选择的主流数据库:shell

类别 数据库
关系型数据库 MySQL, SQL Server for Linux, Oracle, DB2, PostgreDB
NoSQL数据库 Radis, HBase, MongoDB

具体数据库的区别分析,网上有不少文章,这儿就再也不多讨论。数据库

在如今讨论的这个架构下,有几个要求:安全

  1. 数据库要是免费的;
  2. 数据库的安装要简单;
  3. 数据库的使用要方便。这个使用,包括管理和开发;
  4. 最重要的一点,是数据后期可扩展成分布式架构,以保证在不改动代码的状况下,支持B、C轮的数据:P。

在这个要求下,咱们选择MongoDB做为主数据库。bash

MongoDB的官网: https://www.mongodb.com服务器

MongoDB最新版下载: https://www.mongodb.com/download-center/community微信

community版和professional版本最大的区别是pro版有InMemoryDB模式,能够依托大内存创建存放在内存中的数据库文件。通常应用,社区版足够。

先看看MongoDB的安装有多简单:

第一步:下载数据库,以4.2.6 for Debian版本为例:

wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-debian92-4.2.6.tgz

下载完成后,打开压缩包,

tar xvf mongodb-linux-x86_64-debian92-4.2.6.tgz -C /your_folder

咱们会获得如下文件,

-rw-r--r-- 1 test test  30608 Apr 17 11:10 LICENSE-Community.txt
-rw-r--r-- 1 test test  16726 Apr 17 11:10 MPL-2
-rw-r--r-- 1 test test   2617 Apr 17 11:10 README
-rw-r--r-- 1 test test  75405 Apr 17 11:10 THIRD-PARTY-NOTICES
-rw-r--r-- 1 test test 183512 Apr 17 11:13 THIRD-PARTY-NOTICES.gotools
drwxr-xr-x 2 test test   4096 Apr 20 19:29 bin

bin目录中,有如下文件,

-rwxr-xr-x 1 test test 12715648 Apr 17 11:12 bsondump
-rwxr-xr-x 1 test test     7694 Apr 17 11:36 install_compass
-rwxr-xr-x 1 test test 47998920 Apr 17 11:36 mongo
-rwxr-xr-x 1 test test 73240640 Apr 17 11:36 mongod
-rwxr-xr-x 1 test test 17526720 Apr 17 11:12 mongodump
-rwxr-xr-x 1 test test 17277000 Apr 17 11:12 mongoexport
-rwxr-xr-x 1 test test 17242056 Apr 17 11:12 mongofiles
-rwxr-xr-x 1 test test 17452192 Apr 17 11:12 mongoimport
-rwxr-xr-x 1 test test 17879808 Apr 17 11:13 mongoreplay
-rwxr-xr-x 1 test test 17851848 Apr 17 11:12 mongorestore
-rwxr-xr-x 1 test test 40628464 Apr 17 11:36 mongos
-rwxr-xr-x 1 test test 17029440 Apr 17 11:12 mongostat
-rwxr-xr-x 1 test test 16707368 Apr 17 11:12 mongotop

其中:

mongo是个shell,用来操做数据库。

mongod是单个数据库的服务程序,每一个数据库都须要一个mongod进程。

mongos是集群的路由和入口,作集群时必需要用到。

别的都是一些管理工具,能够慢慢了解。

第二步:安装&启动

MongoDB自己是一个绿色软件,上一节的下载和解压,就是安装的过程了。

下面是启动数据库。

./mongod --dbpath your_database_folder_path

MongoDB运行,只须要一个数据库文件的存放目录。

当你看到命令执行后,出现一大篇内容,其中有两行:

I  NETWORK  [listener] Listening on 127.0.0.1
I  NETWORK  [listener] waiting for connections on port 27017

的时候,恭喜你,数据库已经上线了。

简单不?

可是必定要记着,运行简单并不等于这是个Access同样的小东西。

这是个大型的基于文档的NoSQL数据库!

若是想查询各个命令都有什么参数,能够在命令后边加 --help 来查询。

例如:

./mongod --help

里面有详细的说明。

下面列几个经常使用的参数:

参数 说明
config 配置文件。MongoDB除了直接用命令行参数外,也能够把参数写在一个配置文件中,而后在config参数引用这个配置文件
port MongoDB默认端口是27017,能够改为任何端口
logpath 默认数据库日志是输出到终端的,能够改成保存到文件(也能够不用这个参数,而在命令行重定向)
bind_ip MongoDB默认绑定IP是127.0.0.1,能够改为任意IP地址。
db_path 数据库文件的保存目录

下面,咱们检查一下数据库的安装是否正确。

咱们用mongo连到数据库进行操做:

$ ./mongo localhost:27017
MongoDB shell version v4.2.5
> use TestDB
switched to db TestDB
> db.collection.insert({"user":"test1"})
WriteResult({ "nInserted" : 1 })
> db.collection.insert({"user":"test2"})
WriteResult({ "nInserted" : 1 })
> db.collection.find()
"_id" : ObjectId("5ea0279699857fc83ddf6ef5"), "user" : "test1" }
> db.collection.find({"user":"test2"})
"_id" : ObjectId("5ea029a599857fc83ddf6ef6"), "user" : "test2" }
exit

在这一节的最后,补充两个问题:

  1. 扩展性

上面介绍的是单MongoDB数据库的安装。这是最简单的一种形式,也是应用最多的一种形式。

若是数据很重要,为了防止任何状况的数据丢失,能够采用 Master + N Slave 的方式,作主从结构,把一样的多个库放到多个服务器上,互为备份。同时,这种方式还能够实现读写分离。

若是数据量再大,则能够把数据库扩展成集群,用以增长数据库的容量,并提高访问性能。

  1. 安全

上面介绍安装的时候,采用的默认端口。在实际使用时,能够改换一个端口,减小被扫描攻击的机率。

另外,数据库默认安装时,是不检查用户的。换言之,就是任何人均可以连到数据库。若是用在生产服务器上,必定要在数据库中建议用户和权限,以保证阻挡非法的访问。

MongoDB的安全问题,我会单独写一篇文章来讲,敬请关注。

(未完待续)

 


 

微信公众号:老王Plus

扫描二维码,关注我的公众号,能够第一时间获得最新的我的文章和内容推送

本文版权归做者全部,转载请保留此声明和原文连接

相关文章
相关标签/搜索