MongoDB(一):CentOS7离线安装MongoDB单机版与简单使用

CentOS7离线安装MongoDB单机版与简单使用

  • 1、概述
  • 2、安装社区版
    • 2.1、前置条件
    • 2.2、下载.tgz文件
    • 2.3、解压文件
    • 2.4、安装MongoDB Shell
  • 3、运行MongoDB服务端
    • 3.1、关于ulimit
    • 3.2、目录设置
    • 3.3、创建mongod.conf
    • 3.4、运行MongoDB
    • 3.5、检查MongoDB是否已运行
  • 4、使用MongoDB
    • 4.1、操作数据库
      • 4.1.1、显示当前数据库
      • 4.1.2、显示所有数据库
      • 4.1.3、切换到其他数据库
    • 4.2、对集合的操作
      • 4.2.1、显示数据库中所有集合
      • 4.2.2、创建集合
      • 4.2.3、删除集合
      • 4.2.3、集合改名
    • 4.3、对文档的操作
      • 4.3.1、插入文档
      • 4.3.2、查询文档
      • 4.3.3、更新文档
      • 4.3.4、删除文档
  • 5、总结

1、概述

大家好,我是欧阳方超,可以关注我的公众号“欧阳方超”,后续内容将在公众号首发。
由于服务器处于内网去,所有本篇介绍使用.tgz包安装MongoDB的服务端,尽管使用.tgz包可以完成MongoDB服务端的安装,但是官方依然推荐使用yum包管理器来进行安装,因为yum包管理器会自动安装所需要的依赖,并且还会提供一个名为mongod.conf的示例文件,方便将来升级及维护工作,使用.tgz安装的话,该文件需要自行创建。使用.tgz安装服务端后,还需要单独安装 mongosh,在没有GUI连接工具的情况下,可以通过mongosh命令行连接MongoDB服务端。

2、安装社区版

2.1、前置条件

MongoDB依赖libcurl、openssl、xz-libs这几个包,请确保机器上已经安装这些包,可以使用下面的命令检查相关依赖是否已安装,比如下面的命令查询openssl是否已安装:

rpm -qa|grep openssl

如果已安装的话,会有内容返回:

openssl-1.0.2k-21.el7_9.x86_64
openssl-static-1.0.2k-21.el7_9.x86_64
openssl-devel-1.0.2k-21.el7_9.x86_64
openssl-libs-1.0.2k-21.el7_9.x86_64

2.2、下载.tgz文件

根据操作系统选择不合适的版本进行下载,这里已下面的版本为例进行安装:

mongodb-linux-x86_64-rhel70-7.0.2.tgz

2.3、解压文件

解压文件到指定目录,

tar -zxvf mongodb-linux-x86_64-rhel70-7.0.2.tgz -C /path/to/destination

这里暂时先不降MongoDB的二进制命令配置到系统的PATH中,如果需要找二进制命令的话直接到安装目录去找即可。

2.4、安装MongoDB Shell

作为一个追求使用命令行的少年,哪能错过使用命令行的快乐,所以mongosh必须要装啊,这里也下载的.tgz包:

mongosh-2.0.2-linux-x64.tgz

同样,将其解压到指定目录:

tar -zxvf mongosh-2.0.2-linux-x64.tgz -C /path/to/destination

在解压目录的bin目录下,可以看到mongosh命令:

-rwxr-xr-x 1 root root 111667760 Oct 14 20:23 mongosh
-rwxr-xr-x 1 root root 107165512 Oct 14 20:23 mongosh_crypt_v1.so

不过别着急用,因为MongoDB的server还没启动。

3、运行MongoDB服务端

3.1、关于ulimit

大多数类Unix操作系统限制进程可以使用的系统资源。这些限制可能会对MongoDB的运行产生负面影响,因此应进行调整,这里可以所搜下UNIX ulimit设置,根据实际情况设置合适的值,测试时设置为了1024000。

3.2、目录设置

跟很多服务一样,MongoDB运行时也会产生数据和日志,数据和日志会存储在默认的位置,这里不打算使用默认目录, 分别为数据和日志创建目录:

/path/to/data
/path/to/log

创建mongod用户及mongod用户组,把数据目录和日志目录的所有者和所属组设置为刚刚创建的用户和用户组。

chown -R mongod:mongod /path/to/data
chown -R mongod:mongod /path/to/log

3.3、创建mongod.conf

先配置下面几个配置项吧,

dbpath=/path/to/data
logpath=/path/to/log/mongodb.log
port=27017
fork=true

dbpath指定了数据目录的存储位置,logpath指定了日志文件的存储位置,注意需要指定到文件,否则启动会报错,port指定运行时占用的端口,可以根据情况调整,fork为true指明以后台方式启动。

3.4、运行MongoDB

使用MongoDB安装目录下的mongod命令,并使用–config或-f指定配置文件,即可启动MongoDB服务。

[root@xxx bin]#  ./mongod -f  /path/to/mongod.conf
about to fork child process, waiting until server is ready for connections.
forked process: 80863
child process started successfully, parent exiting

3.5、检查MongoDB是否已运行

可以使用检查端口号的形式检查MongoDB是否已运行。

[root@xxx bin]# netstat -tunlp|grep 27017
tcp        0      0 127.0.0.1:27017         0.0.0.0:*               LISTEN      977415/./bin/mongod

4、使用MongoDB

之前的操作中已将安装了mongosh,此时只要执行该命令就会默认连接本机的MongoDB服务(以默认端口连接),并进入到test数据库:

[root@hadoop104 bin]# ./mongosh
Current Mongosh Log ID: 6538cf151bec061745212a9b
Connecting to:          mongodb://127.0.0.1:27017/?directConnection=true&serverSelectionTimeoutMS=2000&appName=mongosh+2.0.2Using MongoDB:          7.0.2
Using Mongosh:          2.0.2For mongosh info see: https://docs.mongodb.com/mongodb-shell/------The server generated these startup warnings when booting2023-10-25T16:17:10.127+08:00: Access control is not enabled for the database. Read and write access to data and configuration is unrestricted2023-10-25T16:17:10.127+08:00: You are running this process as the root user, which is not recommended2023-10-25T16:17:10.127+08:00: This server is bound to localhost. Remote systems will be unable to connect to this server. Start the server with --bind_ip <address> to specify which IP addresses it should serve responses from, or with --bind_ip_all to bind to all interfaces. If this behavior is desired, start the server with --bind_ip 127.0.0.1 to disable this warning2023-10-25T16:17:10.130+08:00: You are running on a NUMA machine. We suggest launching mongod like this to avoid performance problems: numactl --interleave=all mongod [other options]2023-10-25T16:17:10.130+08:00: /sys/kernel/mm/transparent_hugepage/enabled is 'always'. We suggest setting it to 'never'2023-10-25T16:17:10.131+08:00: /sys/kernel/mm/transparent_hugepage/defrag is 'always'. We suggest setting it to 'never'2023-10-25T16:17:10.131+08:00: vm.max_map_count is too low
------Deprecation warnings:- Using mongosh on the current operating system is deprecated, and support may be removed in a future release.
See https://www.mongodb.com/docs/mongodb-shell/install/#supported-operating-systems for documentation on supported platforms.
test>

4.1、操作数据库

4.1.1、显示当前数据库

显示当前数据库:

test> db
test

这将显示当前选定的数据库。

4.1.2、显示所有数据库

显示所有数据库:

test> show dbs
admin   40.00 KiB
config  72.00 KiB
local   72.00 KiB
test    72.00 KiB
test>

这将显示服务器上的所有数据库。

4.1.3、切换到其他数据库

注意下面的命令在切换数据库时,如果数据库不存在,则会创建数据库,否则切换到指定数据库:

use <database_name>

将 <database_name> 替换为您要切换到的数据库名称。如果该数据库不存在,MongoDB 将在您首次向其写入数据时创建该数据库。
MongoDB中数据库的概念与关系型数据库中数据库的概念基本一致。

4.2、对集合的操作

4.2.1、显示数据库中所有集合

集合存在于MongoDB的单个数据库中,它等效于关系型数据库中的表。使用下面三种方式都可以查询数据库中的所有集合:

test> show collections
liCollection
test>test> show tables
liCollection
test>test> db.getCollectionNames()
[ 'liCollection' ]
test>

4.2.2、创建集合

使用use命令切换到要创建集合的数据库,使用db.createCollection()命令创建集合,要创建的集合的名称作为参数,例如如下命令创建了一个名为myCollection的集合:

test> db.createCollection("myCollection")
{ ok: 1 }
test>

注意:如果在向集合中插入文档时,假如集合并不存在,那么将自动创建该集合,下面的命令向myCollectionOne集合插入一条数据,但是集合并未事先创建,执行插入操作时集合myCollectionOne将会被自动创建:

test> db.myCollectionOne.insertOne({name:"Jhone", age:23})
{acknowledged: true,insertedId: ObjectId("654ed4c0fba0f2e5ddf52464")
}
test>

4.2.3、删除集合

删除集合,可以使用db.yourCollectionName.drop()命令,下面是删除集合的示例:

test> db.liCollection.drop()
true
test>

如果成功删除选定集合,则 drop() 方法返回 true,否则返回 false。请注意,集合删除是一个不可逆的操作,一旦删除,其中的数据将无法恢复。

4.2.3、集合改名

MongoDB中,可以使用 db.collection.renameCollection() 命令来给集合改名:

test> db.myCollectionOne.renameCollection("newMyCollection")
{ ok: 1 }
test>

4.3、对文档的操作

MongoDB中文档一词源于document,文档的数据结构和JSON基本一致,所有存储在集合中的数据都是BSON格式,

4.3.1、插入文档

使用db.yourCollectionName.insertOne()方法插入单个文档:

test> db.newMyCollection.insertOne({name:"Jhone", age:23})
{acknowledged: true,insertedId: ObjectId("654eddadfba0f2e5ddf52465")
}

使用db.yourCollectioinName.insertMany()方法插入多个文档:

test> db.newMyCollection.insertMany([{name:"Jhone", age:21},{name:"Peter", age:20}])
{acknowledged: true,insertedIds: {'0': ObjectId("654ede7efba0f2e5ddf52467"),'1': ObjectId("654ede7efba0f2e5ddf52468")}
}

4.3.2、查询文档

使用db.yourCollectionName.find()方法查询集合中的文档:

test> db.newMyCollection.find()
[{ _id: ObjectId("654ed4c0fba0f2e5ddf52464"), name: 'Jhone', age: 23 },{ _id: ObjectId("654eddadfba0f2e5ddf52465"), name: 'Jhone', age: 23 },{ _id: ObjectId("654ede65fba0f2e5ddf52466"), name: 'Jhone', age: 21 },{ _id: ObjectId("654ede7efba0f2e5ddf52467"), name: 'Jhone', age: 21 },{ _id: ObjectId("654ede7efba0f2e5ddf52468"), name: 'Peter', age: 20 }
]

该方法会显示集合中的所有文档。
如果要查询单个文档,可以使用db.yourCollectionName.findOne()方法:

test> db.newMyCollection.findOne()
{ _id: ObjectId("654ed4c0fba0f2e5ddf52464"), name: 'Jhone', age: 23 }
test>

4.3.3、更新文档

使用db.yourCollectionName.updateOne()方法更新单个文档,例如下面的命令将名字为Jhone的文档中的age更新为34:
test> db.newMyCollection.updateOne({name:“Jhone”},{$set:{age:34}})
{
acknowledged: true,
insertedId: null,
matchedCount: 1,
modifiedCount: 1,
upsertedCount: 0
}
db.yourCollectionName.updateMany()方法更新符合条件的多个文档:

test> db.newMyCollection.updateMany({name:"Jhone"}, {$set:{age:34}})
{acknowledged: true,insertedId: null,matchedCount: 4,modifiedCount: 3,upsertedCount: 0
}
test> db.newMyCollection.find()
[{ _id: ObjectId("654ed4c0fba0f2e5ddf52464"), name: 'Jhone', age: 34 },{ _id: ObjectId("654eddadfba0f2e5ddf52465"), name: 'Jhone', age: 34 },{ _id: ObjectId("654ede65fba0f2e5ddf52466"), name: 'Jhone', age: 34 },{ _id: ObjectId("654ede7efba0f2e5ddf52467"), name: 'Jhone', age: 34 },{ _id: ObjectId("654ede7efba0f2e5ddf52468"), name: 'Peter', age: 20 }
]

4.3.4、删除文档

使用 db.yourCollectionName.deleteOne() 方法删除单个文档:

test> db.newMyCollection.deleteOne({name:"Jhone"})
{ acknowledged: true, deletedCount: 1 }
test>

使用使用 db.yourCollectionName.deleteMany() 方法删除符合条件的多个文档:

test> db.newMyCollection.deleteMany({name:"Jhone"})
{ acknowledged: true, deletedCount: 3 }
test>

5、总结

以上就是MongoDB的单机安装与简单使用,高阶内容敬请期待。
我是欧阳方超,把事情做好了自然就有兴趣了,如果你喜欢我的文章,欢迎点赞、转发、评论加关注。我们下次见。
这一篇是在酒店所写,写了几个小时终于写完,好畅快:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/178498.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【cfeng-work】架构演进和漫谈

架构漫谈和入门 内容管理 intro分层架构MVC模式分层架构大数据时代的复杂架构 前端架构后端架构运维端架构持续演进变化 本文主要是自己接触架构的一些输出漫谈 cfeng 在work中某次负责了后端一个服务的上线&#xff0c;多个模块一起上&#xff0c;结果上线失败&#xff0c;幸运…

Maven:通过相对路径向jar中添加依赖项

问&#xff1a;我有一个专有的jar&#xff0c;我想把它作为一个依赖项添加到我的pom中。 但我不想把它添加到存储库中。原因是我希望常用的maven命令(如mvn compile等)能够开箱即用。(无需要求开发人员自己将其添加到某个存储库中)。 我希望jar在源代码控制中的第三方库中&…

day22_mysql

今日内容 零、 复习昨日 一、MySQL 一、约束 1.1 约束 是什么? 约束,即限制,就是通过设置约束,可以限制对数据表数据的插入,删除,更新 怎么做? 约束设置的语法,大部分是 create table 表名( 字段 数据类型(长度) 约束, 字段 数据类型(长度) 约束 );1.1 数据类型 其实数据类型…

【经验记录】Ubuntu系统安装xxxxx.tar.gz报错ImportError: No module named setuptools

最近在Anaconda环境下需要离线状态&#xff08;不能联网的情况&#xff09;下安装一个xxxxx.tar.gz格式的包&#xff0c;将对应格式的包解压后&#xff0c;按照如下命令进行安装 sudo python setup.py build # 编译 sudo python setup.py install # 安装总是报错如下信息&am…

初识VBA代码及应用VBA代码第四节:如何录制宏

《VBA之Excel应用》&#xff08;10178983&#xff09;是非常经典的&#xff0c;是我推出的第七套教程&#xff0c;定位于初级&#xff0c;目前是第一版修订。这套教程从简单的录制宏开始讲解&#xff0c;一直到窗体的搭建&#xff0c;内容丰富&#xff0c;实例众多。大家可以非…

使用github copilot

现在的大模型的应用太广了&#xff0c;作为程序员我们当然野可以借助大模型来帮我们敲代码。 下面是自己注册使用github copilot的过程。 一、注册github copilot 1. 需要拥有github账号 &#xff0c;登录github之后&#xff0c;点右侧自己的头像位置&#xff0c;下面会出现…

Linux编译器:gcc/g++的使用

我们在学习编译器时&#xff0c;我们不仅要只会使用编译器&#xff0c;还要理解程序的编译过程。一个程序存在两个不同的环境。第1种是翻译环境&#xff0c;在这个环境中源代码被转换为可执行的机器指令&#xff1b;第2种是执行环境&#xff0c;它用于实际执行代码。本篇文章将…

TrOCR模型微调【基于transformer的光学字符识别】

TrOCR&#xff08;基于 Transformer 的光学字符识别&#xff09;模型是性能最佳的 OCR 模型之一。 在我们之前的文章中&#xff0c;我们分析了它们在单行打印和手写文本上的表现。 然而&#xff0c;与任何其他深度学习模型一样&#xff0c;它们也有其局限性。 TrOCR 在处理开箱…

改进YOLOv8:结合ICCV2023|动态蛇形卷积,构建不规则目标识别网络

🔥🔥🔥 提升多尺度、不规则目标检测,创新提升 🔥🔥🔥 🔥🔥🔥 捕捉图像特征和处理复杂图像特征 🔥🔥🔥 👉👉👉: 本专栏包含大量的新设计的创新想法,包含详细的代码和说明,具备有效的创新组合,可以有效应用到改进创新当中 👉👉👉: �…

人工智能-深度学习之残差网络(ResNet)

随着我们设计越来越深的网络&#xff0c;深刻理解“新添加的层如何提升神经网络的性能”变得至关重要。更重要的是设计网络的能力&#xff0c;在这种网络中&#xff0c;添加层会使网络更具表现力&#xff0c; 为了取得质的突破&#xff0c;我们需要一些数学基础知识。 ResNet沿…

碾压Fast Request!IDEA插件推荐:Apipost-Helper

IDEA是一款功能强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它可以帮助开发人员更加高效地编写、调试和部署软件应用程序。我们在编写完接口代码后需要进行接口调试等操作&#xff0c;一般需要打开额外的调试工具&#xff0c;而今天给大家介绍一款IDEA插件&…

远程登录Linux方法(Linux平台相互远程;Windows远程登录Linux、远程编码、文件传输;无法远程登录的问题解决;c程序的编译)

在实际使用Linux系统过程中我们不可避免的需要远程登录Linux&#xff0c;这是因为未来大家使用Linux服务器的时候你所对应的那台Linux服务器不一定提供界面(服务器可能在外地)。本篇将会介绍远程登录Linux的方法。 文章目录 1. SSH介绍2. Linux平台相互远程及文件传输2.1 Linux…