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.2

Using MongoDB:          7.0.2
Using Mongosh:          2.0.2

For mongosh info see: https://docs.mongodb.com/mongodb-shell/

------
   The server generated these startup warnings when booting
   2023-10-25T16:17:10.127+08:00: Access control is not enabled for the database. Read and write access to data and configuration is unrestricted
   2023-10-25T16:17:10.127+08:00: You are running this process as the root user, which is not recommended
   2023-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 warning
   2023-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的单机安装与简单使用,高阶内容敬请期待。
我是欧阳方超,把事情做好了自然就有兴趣了,如果你喜欢我的文章,欢迎点赞、转发、评论加关注。我们下次见。
这一篇是在酒店所写,写了几个小时终于写完,好畅快:
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算不上最全,但都是必备——Spring这些不会不行啊

Spring 篇 Spring框架中的单例bean是线程安全的吗&#xff1f; 不是线程安全的 Spring bean并没有可变的状态(比如Service类和DAO类)&#xff0c;所以在某种程度上说Spring的单例bean是线程安全的。 Spring框架中有一个Scope注解&#xff0c;默认的值就是singleton&#xff0…

Java基础(第七期):Java面向对象和类 类的封装 Java构造器 JavaBean标准

Java基础专栏 Java基础&#xff08;第七期&#xff09; 面相对象 面向对象&#xff08;Object-oriented&#xff09;是一种编程思想和方法&#xff0c;它将程序的设计和组织建立在对象的概念上。在Java中&#xff0c;每个对象都是类的一个实例&#xff0c;而类定义了相同类型对…

博流BL602芯片 - 烧录配置

硬件介绍 淘宝上买的核心板&#xff0c;大概结构如上。 直接插入电脑usb&#xff0c;即可实现供电、下载&#xff08;控制BOOT/EN&#xff09;、串口通讯 固件包 1、环境配置 1.1串口 开发板使用了 CH340G 的 USB 转串口芯片&#xff0c;自行安装CH340串口驱动。 1.2编译环境…

mysql之搭建MMM架构实现高可用

实验目的 解决mysql的主从服务器单点故障问题&#xff0c;实现高可用 实验思路 实验条件&#xff1a; 主机名 作用 IP地址 组件 mysql1 master01 20.0.0.13 mysql服务、mysql-mmm mysql2 masert02 20.0.0.23 mysql服务、mysql-mmm mysql3 slave01 20.0.0.33 …

WorkPlus AI助理知识问答机器人,助力企业级私有化AI构建

ChatGPT以及其他大语言模型展现了令人惊叹的广博知识、语义理解能力与创造能力。它们能够在会话中承认自身错误并进行改正&#xff0c;还能进行一定程度的逻辑推理&#xff0c;具备多语种翻译与多语言编程等"超能力"&#xff0c;可胜任多种自然语言处理任务。 然而&…

小黑完成了最后一节健身课,顺利完成了跳绳比赛,乘飞机到达南京准备第二天领物资和南京城内闲逛的leetcode之旅:215. 数组中的第K个最大元素

小黑代码 class Solution:def findKthLargest(self, nums: List[int], k: int) -> int:# 数组长度n len(nums)nums list(map(lambda x:-x, nums))q []for i in range(n):heapq.heappush(q, nums[i])# 出堆target -1for i in range(k):target heapq.heappop(q)return -…

【Python+selenium】自动化生成测试报告

批量执行完用例后&#xff0c;生成的测试报告是文本形式的&#xff0c;不够直观&#xff0c;为了更好的展示测试报告&#xff0c;最好是生成HTML格式的。 unittest里面是不能生成html格式报告的&#xff0c;需要导入一个第三方的模块&#xff1a;HTMLTestRunner 一、入HTMLTe…

jQuery 【关于jQuery 、 jQuery简介、基础选择器、属性选择器、jQuery扩展】(一)-全面详解(学习总结---从入门到深化)

目录 关于jQuery jQuery简介 选择器之基础选择器(一) 选择器之基础选择器(二) 选择器之属性选择器(一) 选择器之属性选择器(二) 选择器之jQuery扩展(一) 选择器之jQuery扩展(二) 关于jQuery 现在是否还需要学习jQuery&#xff0c;毫无疑问到目前为止&#xff0c;我们仍然…

CentOS to KeyarchOS 系统迁移体验

1. KOS(KeyarchOS)——云峦操作系统简介 KeyarchOS 即云峦操作系统(简称 KOS)是浪潮信息基于 Linux 内核、龙蜥等开源技术自主研发的一款服务器操作系统&#xff0c;支持x86、ARM 等主流架构处理器&#xff0c;广泛兼容传统 CentOS 生态产品和创新技术产品&#xff0c;可为用户…

【Docker】实现JMeter分布式压测

一个JMeter实例可能无法产生足够的负载来对你的应用程序进行压力测试。如本网站所示&#xff0c;一个JMeter实例将能够控制许多其他的远程JMeter实例&#xff0c;并对你的应用程序产生更大的负载。JMeter使用Java RMI[远程方法调用]来与分布式网络中的对象进行交互。JMeter主站…

python socket编程2 - socket创建发送方所需参数的获得

使用socket进行进程间通信或者跨网络的计算机间通讯&#xff0c;有点类似日常生活中的发送快递。 根据发送方的需要&#xff0c;选择不同的物流公司&#xff1a; 在选择适合的公司和运输方式后&#xff0c;需要在app上做出选择&#xff0c;并根据要求填写一些信息。app会根据…

tsmc12 nm boundary cell注意事项

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 拾陆楼知识星球入口 往期文章导读: boundary cell添加失败问题整理 注意N/P的区别 针对上下两边的boundary cell,有N/P类型的区别,看版图衬底形状上下是不对称的,而且P

Mac M3 芯片安装 Nginx

Mac M3 芯片安装 Nginx 一、使用 brew 安装 未安装 brew 的可以参考 【Mac 安装 Homebrew】 或者 【Mac M2/M3 芯片环境配置以及常用软件安装-前端】 二、查看 nginx 信息 通过命令行查看 brew info nginx可以看到 nginx 还未在本地安装&#xff0c;显示 Not installed …

白帽黑客一般一个月收入多少?

最近有人问我&#xff0c;像我们这种白帽黑客&#xff0c;一个月能赚多少&#xff1f;其实啊&#xff0c;网上那种搞盗号或做挂的&#xff0c;都不算正经的黑客&#xff0c;真正的黑客绝对不会干这种事情&#xff0c;因为搞这种事都会涉及违法入侵、破坏计算机系统。 先不说赚…

C++ Qt 学习(八):Qt 绘图技术与图形视图

1. 常见 18 种 Qt 绘图技术 1.1 widget.h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <memory> #include <QTreeView> #include "CPaintWidget.h"using namespace std;class Widget : public QWidget {Q_OBJECTpublic:Widget…

LOWORD, HIWORD, LOBYTE, HIBYTE的解释

文章目录 实验结论 实验 int 类型大小正常为4Byte 以小端序来看 0x12345678在内存中的存储为 0x78 0x56 0x34 0x120x78在低地址&#xff0c;0x12在高地址 程序输出 #include <stdio.h> #include <string.h> #include<windows.h>int main() {int a 0x12345…

d3dcompiler_43.dll丢失了怎么办,详细解答和d3dcompiler_43.dll修复方法

以下将为您提供几种处理d3dcompiler_43.dll文件丢失的解决措施&#xff0c;这些方法实用有效&#xff0c;可以帮助我们恢复计算机运行。 一.d3dcompiler_43.dll是什么 在我们开始探讨如何修复d3dcompiler_43.dll文件丢失的问题之前&#xff0c;首先需要了解这个文件的作用。该…

现场直击!触想智能亮相德国2023 SPS展会

当地时间11月14日上午9时 2023 年(德国)纽伦堡国际工业自动化及元器件展览会 SPS 展(以下简称&#xff1a;SPS展会)正式拉开帷幕&#xff0c;触想智能与来自全球各地的领先科技公司及前沿业者齐聚盛会&#xff0c;共赴一场科技与创新交汇的“饕餮盛宴”。 △ 2023 SPS展会开幕(…

可怕!.Net 8正式发布了,.Net野心确实不小!

随着三天.NET Conf 2023的会议结束了&#xff0c;.Net 8正式发布了。 .Net 8是官方号称有史以来性能最快的一个版本了。 .Net 8 增加了数以千计的性能、稳定性和安全性改进&#xff0c;以及平台和工具增强功能&#xff0c;有助于提高开发人员的工作效率和创新速度。 反正就是…