文档章节

mongodb3.2复制集和shard集群搭建

 空灵飞渡
发布于 2016/11/04 14:26
字数 2568
阅读 18
收藏 0
点赞 0
评论 0

三台机器操作系统环境如下:

1

2

3

4

5

6

7

[mongodb@node1 ~]$ cat /etc/issue

CentOS release 6.4 (Final)

Kernel \r on an \m

[mongodb@node1 ~]$ uname -r

2.6.32-358.el6.x86_64

[mongodb@node1 ~]$ uname -m

x86_64

 

架构如下图,之前的架构图找不到了,就凑合看下面的表格吧。。

wKiom1bfhbagjVaTAAGCoOPjNbU972.jpg

 

192.168.75.128、shard1:10001、shard2:10002、shard3:10003、configsvr:10004、mongos:10005

注:shard1主节点,shard2仲裁,shard3副本

192.168.75.129、shard1:10001、shard2:10002、shard3:10003、configsvr:10004、mongos:10005

注:shard1副本,shard2主节点,shard3仲裁

192.168.75.130、shard1:10001、shard2:10002、shard3:10003、configsvr:10004、mongos:10005

注:shard1仲裁,shard2副本,shard3主节点

node1:192.168.75.128

node2:192.168.75.129

node3:192.168.75.130

 

创建mongodb用户

1

2

3

4

5

[root@node1 ~]# groupadd  mongodb

[root@node1 ~]# useradd  -g mongodb mongodb

[root@node1 ~]# mkdir /data

[root@node1 ~]# chown mongodb.mongodb /data -R

[root@node1 ~]# su - mongodb

创建目录和文件

1

2

3

4

5

6

[mongodb@node1 ~]$ mkdir /data/{config,shard1,shard2,shard3,mongos,logs,configsvr,keyfile} -pv

[mongodb@node1 ~]$ touch /data/keyfile/zxl

[mongodb@node1 ~]$ touch /data/logs/shard{1..3}.log

[mongodb@node1 ~]$ touch /data/logs/{configsvr,mongos}.log

[mongodb@node1 ~]$ touch /data/config/shard{1..3}.conf

[mongodb@node1 ~]$ touch /data/config/{configsvr,mongos}.conf

下载mongodb

1

2

3

[mongodb@node1 ~]$ wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.2.3.tgz

[mongodb@node3 ~]$ tar fxz mongodb-linux-x86_64-rhel62-3.2.3.tgz -C /data

[mongodb@node3 ~]$ ln -s /data/mongodb-linux-x86_64-rhel62-3.2.3 /data/mongodb

配置mongodb环境变量

1

2

[mongodb@node1 ~]$ echo "export PATH=$PATH:/data/mongodb/bin" >> ~/.bash_profile

[mongodb@node1 data]$ source ~/.bash_profile

 

shard1.conf配置文件内容如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

[mongodb@node1 ~]$ cat /data/config/shard1.conf 

systemLog:

  destination: file

  path: /data/logs/shard1.log

  logAppend: true

processManagement:

  fork: true

  pidFilePath: "/data/shard1/shard1.pid"

net:

  port: 10001

storage:

  dbPath: "/data/shard1"

  engine: wiredTiger

  journal:

    enabled: true

  directoryPerDB: true

operationProfiling:

  slowOpThresholdMs: 10

  mode: "slowOp"

#security:

#  keyFile: "/data/keyfile/zxl"

#  clusterAuthMode: "keyFile"

replication:

  oplogSizeMB: 50

  replSetName: "shard1_zxl"

  secondaryIndexPrefetch: "all"

shard2.conf配置文件内容如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

[mongodb@node1 ~]$ cat /data/config/shard2.conf 

systemLog:

  destination: file

  path: /data/logs/shard2.log

  logAppend: true

processManagement:

  fork: true

  pidFilePath: "/data/shard2/shard2.pid"

net:

  port: 10002

storage:

  dbPath: "/data/shard2"

  engine: wiredTiger

  journal:

    enabled: true

  directoryPerDB: true

operationProfiling:

  slowOpThresholdMs: 10

  mode: "slowOp"

#security:

#  keyFile: "/data/keyfile/zxl"

#  clusterAuthMode: "keyFile"

replication:

  oplogSizeMB: 50

  replSetName: "shard2_zxl"

  secondaryIndexPrefetch: "all"

shard3.conf配置文件内容如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

[mongodb@node1 ~]$ cat /data/config/shard3.conf 

systemLog:

  destination: file

  path: /data/logs/shard3.log

  logAppend: true

processManagement:

  fork: true

  pidFilePath: "/data/shard3/shard3.pid"

net:

  port: 10003

storage:

  dbPath: "/data/shard3"

  engine: wiredTiger

  journal:

    enabled: true

  directoryPerDB: true

operationProfiling:

  slowOpThresholdMs: 10

  mode: "slowOp"

#security:

#  keyFile: "/data/keyfile/zxl"

#  clusterAuthMode: "keyFile"

replication:

  oplogSizeMB: 50

  replSetName: "shard3_zxl"

  secondaryIndexPrefetch: "all"

configsvr.conf配置文件内容如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

[mongodb@node1 ~]$ cat /data/config/configsvr.conf 

systemLog:

  destination: file

  path: /data/logs/configsvr.log

  logAppend: true

processManagement:

  fork: true

  pidFilePath: "/data/configsvr/configsvr.pid"

net:

  port: 10004

storage:

  dbPath: "/data/configsvr"

  engine: wiredTiger

  journal:

    enabled: true

#security:

#  keyFile: "/data/keyfile/zxl"

#  clusterAuthMode: "keyFile"

sharding:

  clusterRole: configsvr

mongos.conf配置文件内容如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

[mongodb@node3 ~]$ cat /data/config/mongos.conf 

systemLog:

  destination: file

  path: /data/logs/mongos.log

  logAppend: true

processManagement:

  fork: true

  pidFilePath: /data/mongos/mongos.pid

net:

  port: 10005

sharding:

  configDB: 192.168.75.128:10004,192.168.75.129:10004,192.168.75.130:10004

#security:

#  keyFile: "/data/keyfile/zxl"

#  clusterAuthMode: "keyFile"

注:以上操作只是在node1机器上操作,请把上面这些操作步骤在另外2台机器操作一下,包括创建用户创建目录文件以及安装mongodb等,以及文件拷贝到node2、node3对应的目录下,拷贝之后查看一下文件的属主属组是否为mongodb。关于configsvr的问题,官方建议1台或者3台,最好为奇数,你懂得。不懂的话自行搜索mongodb官方就知道答案了,链接找不到了,自己找找吧。

启动各个机器节点的mongod,shard1、shard2、shard3

1

2

3

4

5

[mongodb@node1 ~]$ mongod -f /data/config/shard1.conf

mongod: /usr/lib64/libcrypto.so.10: no version information available (required by m

mongod: /usr/lib64/libcrypto.so.10: no version information available (required by m

mongod: /usr/lib64/libssl.so.10: no version information available (required by mong

mongod: relocation error: mongod: symbol TLSv1_1_client_method, version libssl.so.1n file libssl.so.10 with link time reference

注:无法启动,看到相应的提示后

解决:安装openssl即可,三台机器均安装openssl-devel

1

2

3

[mongodb@node1 ~]$ su - root

Password: 

[root@node1 ~]# yum install openssl-devel -y

再次切换mongodb用户启动三台机器上的mongod,shard1、shard2、shard3

1

2

3

4

5

6

7

8

9

10

11

12

[mongodb@node1 ~]$ mongod -f /data/config/shard1.conf

about to fork child process, waiting until server is ready for connections.

forked process: 1737

child process started successfully, parent exiting

[mongodb@node1 ~]$ mongod -f /data/config/shard2.conf

about to fork child process, waiting until server is ready for connections.

forked process: 1760

child process started successfully, parent exiting

[mongodb@node1 ~]$ mongod -f /data/config/shard3.conf

about to fork child process, waiting until server is ready for connections.

forked process: 1783

child process started successfully, parent exiting

进入node1机器上的mongod:10001登录

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

[mongodb@node1 ~]$ mongo --port 10001

MongoDB shell version: 3.2.3

connecting to: 127.0.0.1:10001/test

Welcome to the MongoDB shell.

For interactive help, type "help".

For more comprehensive documentation, see

http://docs.mongodb.org/

Questions? Try the support group

http://groups.google.com/group/mongodb-user

Server has startup warnings: 

2016-03-08T13:28:18.508+0800 I CONTROL  [initandlisten] 

2016-03-08T13:28:18.508+0800 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/epage/enabled is 'always'.

2016-03-08T13:28:18.508+0800 I CONTROL  [initandlisten] **        We suggest settin

2016-03-08T13:28:18.508+0800 I CONTROL  [initandlisten] 

2016-03-08T13:28:18.508+0800 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/epage/defrag is 'always'.

2016-03-08T13:28:18.508+0800 I CONTROL  [initandlisten] **        We suggest settin

2016-03-08T13:28:18.508+0800 I CONTROL  [initandlisten]

注:提示warning......

解决:在三台机器上均操作一下内容即可

1

2

3

4

[mongodb@node2 config]$ su - root

Password

[root@node1 ~]# echo never > /sys/kernel/mm/transparent_hugepage/enabled

[root@node1 ~]# echo never > /sys/kernel/mm/transparent_hugepage/defrag

关闭三台机器上的mongod实例,然后再次启动三台机器上mongod实例即可。

1

2

3

4

[mongodb@node1 ~]$ netstat -ntpl|grep mongo|awk '{print $NF}'|awk -F'/' '{print $1}'|xargs kill 

[mongodb@node1 ~]$ mongod -f /data/config/shard1.conf

[mongodb@node1 ~]$ mongod -f /data/config/shard2.conf

[mongodb@node1 ~]$ mongod -f /data/config/shard3.conf

配置复制集

node1机器上操作配置复制集

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

[mongodb@node1 config]$ mongo --port 10001

MongoDB shell version: 3.2.3

connecting to: 127.0.0.1:10001/test

> use admin

switched to db admin

> config = { _id:"shard1_zxl", members:[

... ... {_id:0,host:"192.168.75.128:10001"},

... ... {_id:1,host:"192.168.75.129:10001"},

... ... {_id:2,host:"192.168.75.130:10001",arbiterOnly:true}

... ... ]

... ... }

{

"_id" "shard1_zxl",

"members" : [

{

"_id" : 0,

"host" "192.168.75.128:10001"

},

{

"_id" : 1,

"host" "192.168.75.129:10001"

},

{

"_id" : 2,

"host" "192.168.75.130:10001",

"arbiterOnly" true

}

]

}

> rs.initiate(con

config                 connect(               connectionURLTheSame(  constructor

> rs.initiate(config)

"ok" : 1 }

node2机器上操作配置复制集

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

[mongodb@node2 config]$ mongo --port 10002

MongoDB shell version: 3.2.3

connecting to: 127.0.0.1:10002/test

Welcome to the MongoDB shell.

For interactive help, type "help".

For more comprehensive documentation, see

http://docs.mongodb.org/

Questions? Try the support group

http://groups.google.com/group/mongodb-user

> use admin

switched to db admin

> config = { _id:"shard2_zxl", members:[

... ... {_id:0,host:"192.168.75.129:10002"},

... ... {_id:1,host:"192.168.75.130:10002"},

... ... {_id:2,host:"192.168.75.128:10002",arbiterOnly:true}

... ... ]

... ... }

{

"_id" "shard2_zxl",

"members" : [

{

"_id" : 0,

"host" "192.168.75.129:10002"

},

{

"_id" : 1,

"host" "192.168.75.130:10002"

},

{

"_id" : 2,

"host" "192.168.75.128:10002",

"arbiterOnly" true

}

]

}

> rs.initiate(config)

"ok" : 1 }

node3机器上操作配置复制集

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

[mongodb@node3 config]$ mongo --port 10003

MongoDB shell version: 3.2.3

connecting to: 127.0.0.1:10003/test

Welcome to the MongoDB shell.

For interactive help, type "help".

For more comprehensive documentation, see

http://docs.mongodb.org/

Questions? Try the support group

http://groups.google.com/group/mongodb-user

> use admin

switched to db admin

>  config = {_id:"shard3_zxl", members:[

... ... {_id:0,host:"192.168.75.130:10003"},

... ... {_id:1,host:"192.168.75.128:10003"},

... ... {_id:2,host:"192.168.75.129:10003",arbiterOnly:true}

... ... ]

... ... }

{

"_id" "shard3_zxl",

"members" : [

{

"_id" : 0,

"host" "192.168.75.130:10003"

},

{

"_id" : 1,

"host" "192.168.75.128:10003"

},

{

"_id" : 2,

"host" "192.168.75.129:10003",

"arbiterOnly" true

}

]

}

> rs.initiate(config)

"ok" : 1 }

注:以上是配置rs复制集,相关命令如:rs.status(),查看各个复制集的状况

启动三台机器上的configsvr和mongos节点

1

2

3

4

5

6

7

8

[mongodb@node1 logs]$ mongod -f /data/config/configsvr.conf

about to fork child process, waiting until server is ready for connections.

forked process: 6317

child process started successfully, parent exiting

[mongodb@node1 logs]$ mongos -f /data/config/mongos.conf

about to fork child process, waiting until server is ready for connections.

forked process: 6345

child process started successfully, parent exiting

配置shard分片

在node1机器上配置shard分片

1

2

3

4

5

6

7

8

9

10

11

[mongodb@node1 config]$ mongo --port 10005

MongoDB shell version: 3.2.3

connecting to: 127.0.0.1:10005/test

mongos> use admin

switched to db admin

mongos> db.runCommand({addshard:"shard1_zxl/192.168.75.128:10001,192.168.75.129:10001,192.168.75.130:10001"});

"shardAdded" "shard1_zxl""ok" : 1 }

mongos> db.runCommand({addshard:"shard2_zxl/192.168.75.128:10002,192.168.75.129:10002,192.168.75.130:10002"});

"shardAdded" "shard2_zxl""ok" : 1 }

mongos> db.runCommand({addshard:"shard3_zxl/192.168.75.128:10003,192.168.75.129:10003,192.168.75.130:10003"});

"shardAdded" "shard3_zxl""ok" : 1 }

1

2

3

4

#db.runCommand({addshard:"shard1_zxl/192.168.33.131:10001,192.168.33.132:10001,192.168.33.136:10001"});

#db.runCommand({addshard:"shard2_zxl/192.168.33.131:10002,192.168.33.132:10002,192.168.33.136:10002"});

#db.runCommand({addshard:"shard3_zxl/192.168.33.131:10003,192.168.33.132:10003,192.168.33.136:10003"});

注:根据自己的实际情况,修改上面内容,快速执行。。你懂得。。

查看shard信息

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

mongos> sh.status()

--- Sharding Status --- 

  sharding version: {

"_id" : 1,

"minCompatibleVersion" : 5,

"currentVersion" : 6,

"clusterId" : ObjectId("56de6f4176b47beaa9c75e9d")

}

  shards:

{  "_id" "shard1_zxl",  "host" "shard1_zxl/192.168.75.128:10001,192.168.75.129:10001" }

{  "_id" "shard2_zxl",  "host" "shard2_zxl/192.168.75.129:10002,192.168.75.130:10002" }

{  "_id" "shard3_zxl",  "host" "shard3_zxl/192.168.75.128:10003,192.168.75.130:10003" }

  active mongoses:

"3.2.3" : 3

  balancer:

Currently enabled:  yes

Currently running:  no

Failed balancer rounds in last 5 attempts:  0

Migration Results for the last 24 hours: 

No recent migrations

  databases:

查看分片状态

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

mongos> db.runCommand( {listshards : 1 } )

{

"shards" : [

{

"_id" "shard1_zxl",

"host" "shard1_zxl/192.168.75.128:10001,192.168.75.129:10001"

},

{

"_id" "shard2_zxl",

"host" "shard2_zxl/192.168.75.129:10002,192.168.75.130:10002"

},

{

"_id" "shard3_zxl",

"host" "shard3_zxl/192.168.75.128:10003,192.168.75.130:10003"

}

],

"ok" : 1

}

启用shard分片的库名字为'zxl',即为库

1

2

mongos> sh.enableSharding("zxl")

"ok" : 1 }

设置集合的名字以及字段,默认自动建立索引,zxl库,haha集合

1

2

mongos> sh.shardCollection("zxl.haha",{age: 1, name: 1})

"collectionsharded" "zxl.haha""ok" : 1 }

模拟在haha集合中插入10000数据

1

2

mongos> for (i=1;i<=10000;i++) db.haha.insert({name: "user"+i, age: (i%150)})

WriteResult({ "nInserted" : 1 })

可以使用上面mongos> sh.status()命令查看各个shard分片情况,以上就是复制集和shard分片搭建完成,主要还是需要理解rs和shard原理。还是把结果发出来吧,如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

mongos> sh.status()

--- Sharding Status --- 

  sharding version: {

"_id" : 1,

"minCompatibleVersion" : 5,

"currentVersion" : 6,

"clusterId" : ObjectId("56de6f4176b47beaa9c75e9d")

}

  shards:

{  "_id" "shard1_zxl",  "host" "shard1_zxl/192.168.75.128:10001,192.168.75.129:10001" }

{  "_id" "shard2_zxl",  "host" "shard2_zxl/192.168.75.129:10002,192.168.75.130:10002" }

{  "_id" "shard3_zxl",  "host" "shard3_zxl/192.168.75.128:10003,192.168.75.130:10003" }

  active mongoses:

"3.2.3" : 3

  balancer:

Currently enabled:  yes

Currently running:  no

Failed balancer rounds in last 5 attempts:  0

Migration Results for the last 24 hours: 

2 : Success

  databases:

{  "_id" "zxl",  "primary" "shard3_zxl",  "partitioned" true }

zxl.haha

shard key: { "age" : 1, "name" : 1 }

unique: false

balancing: true

chunks:

shard1_zxl1

shard2_zxl1

shard3_zxl1

"age" : { "$minKey" : 1 }, "name" : { "$minKey" : 1 } } -->> { "age" : 2, "name" "user2" } on : shard1_zxl Timestamp(2, 0) 

"age" : 2, "name" "user2" } -->> { "age" : 22, "name" "user22" } on : shard2_zxl Timestamp(3, 0) 

"age" : 22, "name" "user22" } -->> { "age" : { "$maxKey" : 1 }, "name" : { "$maxKey" : 1 } } on : shard3_zxl Timestamp(3, 1)

以上就是mongodb3.2复制集和shard分片搭建就此完成,还是多多看看各个角色是什么概念以及原理性的东东吧。。

本文转载自:http://noodle.blog.51cto.com/2925423/1749028

共有 人打赏支持
粉丝 3
博文 176
码字总数 81638
作品 0
广州
mongodb复制集+分片生产环境实践

三台机器操作系统环境如下: [mongodb@node1 ~]$ cat /etc/issueRed Hat Enterprise Linux Server release 6.6 (Santiago)Kernel r on an m[mongodb@node1 ~]$ uname -r2.6.32-504.el6.x86_6......

盖世英雄iii
06/27
0
0
mongodb 3.4 集群搭建:分片+副本集

mongodb是最常用的nodql数据库,在数据库排名中已经上升到了前六。这篇文章介绍如何搭建高可用的mongodb(分片+副本)集群。 在搭建集群之前,需要首先了解几个概念:路由,分片、副本集、配...

纯洁的虫纸
2017/08/11
0
0
搭建高可用MongoDB集群(分片)

MongoDB基础请参考:http://blog.51cto.com/kaliarch/2044423 MongoDB(replica set)请参考:http://blog.51cto.com/kaliarch/2044618 一、概述 1.1 背景 为解决mongodb在replica set每个从......

KaliArch
2017/12/04
0
0
mongoDB高可用集群环境搭建

在生产环境下,部署一台mongodb服务的话,会存在以下问题: 单点问题 生产环境是一个发杂的环境,在这个过程中会产生很多的问题,发生网络故障,服务器宕机,机房停电等,如果是部署单机服务...

二两豆腐
2016/07/11
149
0
MongoDB集群部署

数据副本 MongoDB中的一组副本是一群mongod进程,这些进程维护同样的数据集。副本集提供了冗余和高可用性,是生产环境部署的基础。 数据冗余和可用性 通过在不同的服务器上存储相同的数据,副...

黄索远
2017/10/17
0
0
mongodb分片集群实战搭建

架构图: 1.准备机器,IP分别设置为 192.168.1.201192.168.1.202192.168.1.203 2.在每个机器上下载mongodb 3.在每个机器上建立mongos.config,shard1,shard2.shard3五个文件夹 mongos:数据库集...

liuxw0226
2015/09/14
301
0
mongodb sharding 集群

目前有已搭好的mongodb 分片集群 状况为:三台 服务器 每台上运行 一个路由进程(mongos) 一个config_sever 和三个分片,其中三台服务器上的每一个相同shard搭建了副本集 --架构如下 seve...

LYcould
2016/03/12
272
0
MongoDB集群分片搭建

操作系统:CentOS 6 x86_64 MongoDB版本:3.4.3 集群主机拓扑: test1-3 分别在一台主机上启动两个不同副本集名称的mongod实例。 test4-6 三台主机作为 config server 单独运行。 test7 主机...

奇葩界张三
2017/05/04
0
0
MongoDb片式集群和Replace sets主从

cd mongodbmongodb-win32-i386-2.4.5bin 分片复制集A(三个分片节点构成一个复制集): 127.0.0.1:20000(主) 127.0.0.1:20001(备) 127.0.0.1:20002(仲裁) 分片复制集B(三个分片节点构成...

守望之心
2013/12/09
305
0
实战mongodb3.06 Relica Sets+sharding集群

实战mongodb3.06 Relica Sets+sharding集群 前 言 MongoDB 的Sharding机制解决了海量存储和动态扩容的问题,但离实际生产环境所需要的高可靠、高可用还有些距离,例如Shard Server的单点故障...

jxzhfei
2015/12/12
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

扫码二维码跳转到某个网站

添加maven依赖 <dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.0.0</version></dependency><dependency><groupId>com.goog......

gaomq
10分钟前
0
0
Windows平台下搭建Git服务器的图文教程

Git没有客户端服务器端的概念,但是要共享Git仓库,就需要用到SSH协议(FTP , HTTPS , SFTP等协议也能实现Git共享,此文档不讨论),但是SSH有客户端服务器端,所以在windows下的开发要把自己...

MKChan
16分钟前
0
0
告警系统主脚本&告警系统配置文件&告警系统监控项目

20.20 告警系统主脚本 准备工作 定义监控系统的各个目录,然后再去定义主脚本,因为是分布式的,所以需要每一台机器都需要定义,事先创建好各个脚本和各个目录,随后脚本直接拷贝过去即可,然...

影夜Linux
17分钟前
0
0
谈谈神秘的ES6——(一)初识ECMAScript

谈谈神秘的ES6——(一)初识ECMAScript 在《零基础入门JavaScript》我们就说过,ECMAScript是JavaScript的核心,是JavaScript语法和语义的解释器,同时也是一个标准。而ECMAScript标准其实也...

JandenMa
今天
1
0
第16章 Tomcat配置

16.1 Tomcat介绍 ####Tomcat介绍 LNMP架构针对的开发语言是PHP语言,php 是一门开发web程序非常流行的语言,早些年流行的是asp,在Windows平台上运行的一种编程语言,但安全性差,就网站开发...

Linux学习笔记
今天
0
0
流利阅读笔记29-20180718待学习

高等教育未来成谜,前景到底在哪里? Ray 2018-07-18 1.今日导读 在这个信息爆炸的年代,获取知识是一件越来越容易的事情。人们曾经认为,如此的时代进步会给高等教育带来众多便利。但事实的...

aibinxiao
今天
12
0
OSChina 周三乱弹 —— 你被我从 osc 老婆们名单中踢出了

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @小鱼丁:分享五月天的单曲《后来的我们 (电影《后来的我们》片名曲)》: 《后来的我们 (电影《后来的我们》片名曲)》- 五月天 手机党少年们想...

小小编辑
今天
704
20
Spring Boot Admin 2.0开箱体验

概述 在我之前的 《Spring Boot应用监控实战》 一文中,讲述了如何利用 Spring Boot Admin 1.5.X 版本来可视化地监控 Spring Boot 应用。说时迟,那时快,现在 Spring Boot Admin 都更新到 ...

CodeSheep
今天
5
0
Python + Selenium + Chrome 使用代理 auth 的用户名密码授权

米扑代理,全球领导的代理品牌,专注代理行业近十年,提供开放、私密、独享代理,并可免费试用 米扑代理官网:https://proxy.mimvp.com 本文示例,是结合米扑代理的私密、独享、开放代理,专...

sunboy2050
今天
0
0
实现异步有哪些方法

有哪些方法可以实现异步呢? 方式一:java 线程池 示例: @Test public final void test_ThreadPool() throws InterruptedException { ScheduledThreadPoolExecutor scheduledThre......

黄威
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部