Olá,
Neste artigo irei abordar a instalação do MongoDB que é um banco de dados orientado a documentos que armazena dados em documentos JSON com esquema dinâmico, ou seja, não existe uma estrutura de dados como quantidade de colunas ou tipos de dados para armazenar valores. Pode-se dizer que os documentos do MongoDB são semelhantes aos objetos JSON. No mais, a instalação do MongoDB se resume apenas em realizar o download de um arquivo ".tgz" e descompactá-lo. Abaixo irei criar as estruturas necessárias e realizar algumas configurações recomendadas. Obs.: Por questões de performance, o sistema de arquivos recomendado para armazenar a partição onde ficará o MongoDB é o XFS já que a engine padrão utilizada pelo mesmo é o WiredTiger.
O primeiro passo é criar os diretórios onde ficarão armazenados os dados dos bancos de dados (/mongodb/data) e os arquivos de log (/mongodb/log). O arquivo de log se assemelha ao arquivo de log do MySQL ou até mesmo o arquivo de alerta do Oracle.
[root@linux ~]# mkdir -p /mongodb
[root@linux ~]# mkdir -p /mongodb/data
[root@linux ~]# mkdir -p /mongodb/log
Após a criação dos diretórios, ire realizar o download do arquivo de instalação do MongoDB 3.6.5 X64 conforme a seguir.
[root@linux ~]# cd /mongodb/
[root@linux mongodb]# wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.6.5.tgz
--2018-06-18 18:06:41-- https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.6.5.tgz
Resolving fastdl.mongodb.org (fastdl.mongodb.org)... 54.230.57.97, 54.230.57.250, 54.230.57.175, ...
Connecting to fastdl.mongodb.org (fastdl.mongodb.org)|54.230.57.97|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 100564462 (96M) [application/x-gzip]
Saving to: 'mongodb-linux-x86_64-rhel70-3.6.5.tgz'
100%[==============================================================================================>] 100,564,462 3.39MB/s in 28s
2018-06-18 18:07:11 (3.39 MB/s) - 'mongodb-linux-x86_64-rhel70-3.6.5.tgz' saved [100564462/100564462]
Com o download realizado, poderemos descompactar o arquivo conforme demonstrado abaixo.
[root@linux mongodb]# tar -xzvf mongodb-linux-x86_64-rhel70-3.6.5.tgz
mongodb-linux-x86_64-rhel70-3.6.5/README
mongodb-linux-x86_64-rhel70-3.6.5/THIRD-PARTY-NOTICES
mongodb-linux-x86_64-rhel70-3.6.5/MPL-2
mongodb-linux-x86_64-rhel70-3.6.5/GNU-AGPL-3.0
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongodump
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongorestore
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoexport
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoimport
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongostat
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongotop
mongodb-linux-x86_64-rhel70-3.6.5/bin/bsondump
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongofiles
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoreplay
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoperf
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongod
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongos
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongo
mongodb-linux-x86_64-rhel70-3.6.5/bin/install_compass
Para fins de segurança e boa prática, irei criar um usuário específico que irá executar o processo do MongoDB.
[root@linux ~]# useradd mongodb
[root@linux ~]# passwd mongodb
Changing password for user mongodb.
New password: *****
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: *****
passwd: all authentication tokens updated successfully.
[root@linux ~]# chown -R mongodb.mongodb /mongodb/
[root@linux mongodb]# ls -lh
total 96M
drwxr-xr-x. 2 mongodb mongodb 4.0K Jun 18 17:59 data
drwxr-xr-x. 2 mongodb mongodb 4.0K Jun 18 17:59 log
drwxr-xr-x. 3 mongodb mongodb 4.0K Jun 18 18:07 mongodb-linux-x86_64-rhel70-3.6.5
-rw-r--r--. 1 mongodb mongodb 96M May 21 20:16 mongodb-linux-x86_64-rhel70-3.6.5.tgz
Para que os utilitários e o próprio executável do MongoDB seja executado de qualquer diretório. irei colocar o caminho do executável na variável $PATH conforme a seguir.
[root@linux ~]# su - mongodb
[mongodb@linux ~]$ cat .bash_profile
# .bash_profile
# Get the aliases and functions
if [ -f ~/.bashrc ]; then
. ~/.bashrc
fi
PATH=$PATH:$HOME/.local/bin:$HOME/bin:/mongodb/mongodb-linux-x86_64-rhel70-3.6.5/bin/
export PATH
Pronto. Agora poderemos iniciar o startup do MongoDB conforme a linda de comando abaixo onde:
- mongod: é o nome do executável do MongoDB
- --fork: utilizado para manter a execução do processo mongod executando em background
- --oplogsize: Oplog é uma collection especial que fica armazenado em um banco de dados de sistema do MongoDB e que armazena todas operações realizadas nos bancos de dados. É equivalente o redo log online do Oracle ou transaction log do SQL Server ou binlog do MySQL. O valor 1024 especifica o tamanho do mesmo e é medido em MB (Megabytes).
- --journal: Este parâmetro junto com a engine WiredTiger que é a default desde a versão 3.2 e é útil como por exemplo, utilizar tecnologia de snapshots de discos (Amazon AWS) de forma que seja possível realizar backups físicos do MongoDB sem gerar indisponibilidade.
- --port: Porta a ser utilizada. O padrão é 27107. Vale a pena salientar que é possível ter várias instâncias em um mesmo servidor executando em portas diferentes.
- --bind_ip_all: Permite acesso externo a instância do MongoDB.
- --dbpath: Caminho onde ficarão armazenados os bancos de dados
- --logpath: Caminho onde ficarão armazenados os arquivos de log
[mongodb@linux ~]$ mongod --fork --oplogSize 1024 --journal --port 27017 --bind_ip_all --dbpath /mongodb/data/ --logpath /mongodb/log/mongodb.log
about to fork child process, waiting until server is ready for connections.
forked process: 2560
child process started successfully, parent exiting
Após subir a instância do MongoDB, podemos conectar na mesma usando o utilitário de linha de comando mongo conforme a seguir.
[mongodb@linux ~]$ mongo --port 27017
MongoDB shell version v3.6.5
connecting to: mongodb://127.0.0.1:27017/
MongoDB server version: 3.6.5
Server has startup warnings:
2018-06-18T18:18:00.125+0100 I STORAGE [initandlisten]
2018-06-18T18:18:00.125+0100 I STORAGE [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2018-06-18T18:18:00.125+0100 I STORAGE [initandlisten] ** See http://dochub.mongodb.org/core/prodnotes-filesystem
2018-06-18T18:18:01.979+0100 I CONTROL [initandlisten]
2018-06-18T18:18:01.979+0100 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2018-06-18T18:18:01.979+0100 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2018-06-18T18:18:01.979+0100 I CONTROL [initandlisten]
2018-06-18T18:18:01.979+0100 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2018-06-18T18:18:01.979+0100 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2018-06-18T18:18:01.979+0100 I CONTROL [initandlisten]
> exit
bye
Para realizar o shutdown da instância, basta proceder com a linha de comando abaixo.
[mongodb@linux ~]$ mongod --dbpath /mongodb/data --shutdown
killing process with pid: 2560
Como a instalação do MongoDB foi realizada em um sistema de arquivos Ext4, é possível observar o alerta de que o sistema de arquivos XFS é altamente recomendado. Para os outros alertas e demais boas práticas irei ajustar o sistema operacional conforme demonstrado abaixo.
-- como root
[root@linux ~]# cat /etc/security/limits.conf
mongodb soft nofile 65535
mongodb hard nofile 65535
mongodb soft nproc 65535
mongodb hard nproc 65535
[mongodb@linux ~]$ ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 11275
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 65535
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 65535
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
[root@linux mongodb]# echo 'never' > /sys/kernel/mm/transparent_hugepage/enabled
[root@linux mongodb]# echo 'never' > /sys/kernel/mm/transparent_hugepage/defrag
[root@linux mongodb]# cat /sys/kernel/mm/transparent_hugepage/enabled
always madvise [never]
[root@linux mongodb]# cat /sys/kernel/mm/transparent_hugepage/defrag
always madvise [never]
Vale a pena salientar que a alteração do transparent_hugepage precisa ser realizado a todo momento em que o servidor é reiniciado. Após realizado os ajustes necessários, irei novamente subir a instância do MongoDB (como mongodb).
[mongodb@linux ~]$ mongod --fork --oplogSize 1024 --journal --port 27017 --bind_ip_all --dbpath /mongodb/data/ --logpath /mongodb/log/mongodb.log
about to fork child process, waiting until server is ready for connections.
forked process: 2836
child process started successfully, parent exiting
[mongodb@linux ~]$ mongo
MongoDB shell version v3.6.5
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.6.5
Server has startup warnings:
2018-06-18T18:27:42.883+0100 I STORAGE [initandlisten]
2018-06-18T18:27:42.883+0100 I STORAGE [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2018-06-18T18:27:42.883+0100 I STORAGE [initandlisten] ** See http://dochub.mongodb.org/core/prodnotes-filesystem
2018-06-18T18:27:44.529+0100 I CONTROL [initandlisten]
> show dbs
admin 0.000GB
config 0.000GB
local 0.000G
Pronto. o comando "show dbs' lista os bancos de dados atualmente criados na instância do MongoDB.
Nenhum comentário:
Postar um comentário