[docker]安装常见数据库
前言
本文使用docker安装常见数据库大部分没配置什么参数,只是基本的安装。
不只是数据库,还有elasticsearch、rabbitmq等和数据相关的服务。
- docker 版本: 18.06.3和19.03.9
- docker-compose 版本: 2.4.0
MySQL(v5.7)
- 下载docker镜像
docker pull mysql:5.7
- 创建并运行docker容器
# 映射宿主机3307端口到容器的3306端口
# 设置mysql的root密码为123456
# 映射宿主机的/home/heruo/mysql/data到容器的/var/lib/mysql
docker run -it --name mysql-test -p 3307:3306\
-e MYSQL_ROOT_PASSWORD=123456 \
-v /home/heruo/mysql/data:/var/lib/mysql \
-v /home/heruo/mysql/conf/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf \
-d mysql:5.7
- docker-compose.yaml
version: "3"
services:
mysql:
image: mysql:5.7
container_name: mysql-test
volumes:
- /home/heruo/mysql/data:/var/lib/mysql
- /home/heruo/mysql/conf/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf
- /etc/localtime:/etc/localtime:ro
ports:
- 3307:3306
environment:
- MYSQL_ROOT_PASSWORD=123456
- mysqld.cnf示例
[mysqld]
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
datadir = /var/lib/mysql
#log-error = /var/log/mysql/error.log
# By default we only accept connections from localhost
#bind-address = 127.0.0.1
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
max_allowed_packet = 32M
lower_case_table_names=1
max_connections=2000
# 禁用查询缓存
query_cache_type=0
query_cache_size=0
# innodb缓冲池大小,此处设置为512MB. 512 * 1024 * 1024
innodb_buffer_pool_size=536870912
# binlog配置
#log-bin=mysql-bin
#binlog-format=ROW
#server-id=1
#binlog_ignore_db=information_schema,mysql,performance_schema,sys
#expire_logs_days=30
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
MariaDB
- 下载docker镜像
docker pull mariadb
- 创建并运行docker容器
# 映射宿主机4306端口到容器的3306端口
# 设置mariadb的root密码为123456
# 映射宿主机的/home/heruo/mariadb/data到容器的/var/lib/mysql
docker run -it --name mariadb-test -p 4306:3306\
-e MARIADB_ROOT_PASSWORD=123456 \
-v /home/heruo/mariadb/data:/var/lib/mysql \
-d mariadb:latest
- docker-compose.yaml
version: "3"
services:
mariadb:
image: mariadb:latest
container_name: mariadb-test
volumes:
- /home/heruo/mariadb/data:/var/lib/mysql
ports:
- 4306:3306
environment:
- MARIADB_ROOT_PASSWORD=123456
Redis(v6.2.4)
- 下载docker镜像
docker pull redis:6.2.4
- 创建并运行docker容器
docker run -p 6379:6379 --name redis-test -d redis:6.2.4
- docker-compose.yaml
version: "3"
services:
redis:
image: redis:6.2.4
container_name: redis-6379
ports:
- 6379:6379
volumes:
- /home/apps/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf
- /home/apps/redis/data:/data
# 挂载redis.conf的话,需要指定启动命令中的配置文件路径
command: redis-server /usr/local/etc/redis/redis.conf
- redis.conf示例
port 6379
requirepass 123456
protected-mode no
daemonize no
appendonly yes
aof-use-rdb-preamble yes
MongoDB
- 下载docker镜像
docker pull mongo
- 创建并运行docker容器
docker run -p 27017:27017 --name mongodb-test \
-v /home/heruo/mongodb/data:/data/db \
-e MONGO_INITDB_ROOT_USERNAME=root \
-e MONGO_INITDB_ROOT_PASSWORD=123456 \
-d mongo:latest
- docker-compose.yaml
version: "3"
services:
mongodb:
image: mongo:latest
container_name: mongodb-test
ports:
- 27017:27017
volumes:
- /home/heruo/mongodb/data:/data/db
environment:
- MONGO_INITDB_ROOT_USERNAME=root
- MONGO_INITDB_ROOT_PASSWORD=123456
elasticsearch(7.5.1)
- 下载docker镜像
docker pull elasticsearch:7.5.1
- 创建并运行docker容器
docker run -p 9200:9200 -p 9300:9300 --name es-test \
-e "discovery.type=single-node" \
-d elasticsearch:7.5.1
- docker-compose.yaml
version: "3"
services:
elasticsearch:
image: elasticsearch:7.5.1
container_name: es-test
ports:
- 9200:9200
- 9300:9300
volumes:
- /home/heruos/apps/elasticsearch/data/:/usr/share/elasticsearch/data
- /home/heruos/apps/elasticsearch/logs/:/usr/share/elasticsearch/logs
- /home/heruos/apps/elasticsearch/plugins/:/usr/share/elasticsearch/plugins
environment:
- "discovery.type=single-node"
- "ES_JAVA_OPTS=-Xms512m -Xmx512m"
ulimits:
nofile:
soft: 65535
hard: 65535
PostgreSQL
- 下载docker容器
docker pull postgres
- 创建并运行docker容器
docker run -p 5432:5432 --name postgresql \
-e POSTGRES_PASSWORD=123456 \
-v /home/heruos/apps/postgresql/data:/var/lib/postgresql/data \
-d postgres
- docker-compose.yaml
version: "3"
services:
postgresql:
image: postgres:latest
container_name: postgresql
ports:
- 5432:5432
volumes:
- /home/heruos/apps/postgresql/data:/var/lib/postgresql/data
environment:
- "POSTGRES_PASSWORD=123456"
Oracle
待施工
DB2
- 拉取容器
docker pull 'ibmcom/db2'
- 创建容器并运行
# 默认实例拥有者是db2inst1
# 设置db2inst1的密码为db2inst1
docker run -itd --name mydb2 --privileged=true -p 50000:50000 -e LICENSE=accept -e DB2INST1_PASSWORD=db2inst1 -e DBNAME=testdb -v /home/apps/db2/data:/database ibmcom/db2
kafka
待施工
rocketmq
待施工
clickhouse
- 拉取镜像
docker pull clickhouse/clickhouse-server
- 创建容器并运行
# 基础创建方式
docker run -d --name some-clickhouse-server --ulimit nofile=262144:262144 clickhouse/clickhouse-server
# 映射端口
docker run -d -p 18123:8123 -p19000:9000 --name clickhouse-server1 --ulimit nofile=262144:262144 clickhouse/clickhouse-server
- 容器中的数据目录为:
/var/lib/clickhouse/ - 容器中的日志目录为:
/var/log/clickhouse-server/
docker-compose.yaml示例:
version: "3"
services:
clickhouse:
image: clickhouse/clickhouse-server:latest
container_name: chserver
volumes:
- /home/apps/clickhouse/data:/var/lib/clickhouse
- /home/apps/clickhouse/logs:/var/log/clickhouse-server
ports:
- 8123:8123
- 9000:9000
ulimits:
nofile:
soft: 262144
hard: 262144
rabbitmq
- 拉取docker镜像
# 带web端管理系统
docker pull rabbitmq:management
- 创建容器并运行
# 15672是web管理端访问端口
docker run --name rabbitmq -p 5672:5672 -p 15672:15672 \
-e RABBITMQ_DEFAULT_USER=rbmq \
-e RABBITMQ_DEFAULT_PASS=rbmq \
--hostname=rabbitmqhosta \
-v /home/rabbitmq/data:/var/lib/rabbitmq \
-d rabbitmq:management
memcache
- 拉取docker容器
docker pull memcached
- 创建容器并运行
# 映射11211端口,指定最大容量为128m。不设置的话,最大容量为64m
docker run --name memcache -p 11211:11211 -d memcached -m 128
- 测试:
telnet 192.168.0.10 11211
# 访问成功后,执行 stats
etcd
待施工
influxdb2
- 拉取docker容器
docker pull influxdb:2.3.0
- 生成配置文件
# 创建挂载目录
mkdir -p /home/apps/influxdb/{conf,data}
# 考虑到后续可能会修改配置,所以先把配置文件导出来了
docker run --rm influxdb:2.3.0 influxd print-config > /home/apps/influxdb/conf/config.yml
- 创建容器并运行
docker run --name influxdb -p 8086:8086 \
-v /home/apps/influxdb/data:/var/lib/influxdb2 \
-v /home/apps/influxdb/conf/config.yml:/etc/influxdb2/config.yml \
-d influxdb:2.3.0
- 测试。浏览器访问 IP:8086
[docker]安装常见数据库的更多相关文章
- Docker学习实践 - Docker安装MySql数据库
Docker安装MySQL数据库 1.Ubuntu安装MySQL安装 (1)安装编译源码需要的包 sudo apt-get install make cmake gcc g++ bison libnc ...
- 使用Docker安装Oracle数据库
在很多时候,我们需要在本地安装Oracle数据库,但是整个安装的过程时间非常长而且安装文件大,那么有不有更好的办法来安装Oracle数据库既能减少安装的时间而且还能够快速进行部署呢?答案就是使用Doc ...
- 心动不如行动,基于Docker安装关系型数据库PostgrelSQL替代Mysql
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_171 最近"全栈数据库"的概念甚嚣尘上,主角就是PostgrelSQL,它最近这几年的技术发展不可谓不猛,覆盖 ...
- mac系统用docker安装oracle数据库
oracle没有mac可用的版本,最好的办法是通过docker安装 一.下载docker 1.通过brew下载 brew cask install docker 2.手动下载(需要vpn) https ...
- Docker安装常见的应用与将本地镜像推送到阿里云
一.Docker安装常用的应用 1,docker安装mysql #拉取镜像mysql5.7 docker pull mysql:5.7 #启动容器(绑定对应的配置文件和日志,默认密码为123456) ...
- Docker安装MySQL数据库
本文翻译自:MySQL Docker Containers:Understanding the basics 1.下载MySQL镜像 docker pull mysql:5.6 如此便可以下载最新的M ...
- docker安装db2数据库
查询可安装的db2镜像 # docker search db2 [root@docker-servers ~]# docker search db2 INDEX NAME DESCRIPTION ST ...
- Docker安装Mysql数据库容器(zz)
zz自:http://blog.csdn.net/chengxuyuanyonghu/article/details/54380032 1.下载mysql的镜像: sudo docker pull m ...
- docker 安装mysql数据库 <二>
一.下载mysql数据库 #网易镜像中心https://c.163.com/hub#/m/home/ #采用网易加速地址,不加速时下载非常的慢 docker pull hub.c..com/libra ...
- docker 安装 sqlserver 数据库
具备条件: 1.服务器需要大于2G内存.如果不够则可能无法正常启动,查看日志报如下错误:This program requires a machine with at least 2000 megab ...
随机推荐
- 优雅的操作文件:java.nio.file 库介绍
概述 在早期的 Java 版本中,文件 IO 操作功能一直相对较弱,主要存在以下问题: 缺乏对现代文件系统的支持:只提供的基础的文件操作,不支持很多现代的文件系统 API 不够直观:文件操作的 API ...
- #Python 利用pivot_table,数据透视表进行数据分析
前面我们分享了,利用python进行数据合并和连接,但是工作中,我们往往需要对数据进一步的聚合或者运算,以求最后的数据结果. 今天我们就来学习一下利用pandas模块,对数据集进行数据透视分析. pi ...
- 2022-06-15:薯队长最近在参加了一个活动,主办方提供了N个礼物以供挑选, 每个礼物有一个价值,范围在0 ~ 10^9之间, 薯队长可以从中挑选k个礼物。 返回:其中价值最接近的两件礼物之间相差
2022-06-15:薯队长最近在参加了一个活动,主办方提供了N个礼物以供挑选, 每个礼物有一个价值,范围在0 ~ 10^9之间, 薯队长可以从中挑选k个礼物. 返回:其中价值最接近的两件礼物之间相差 ...
- 2022-04-07:给定一个只由‘a‘和‘b‘组成的字符串str, str中“ab“和“ba“子串都可以消除, 消除之后剩下字符会重新靠在一起,继续出现可以消除的子串... 你的任务是决定一种消除的
2022-04-07:给定一个只由'a'和'b'组成的字符串str, str中"ab"和"ba"子串都可以消除, 消除之后剩下字符会重新靠在一起,继续出现可以消 ...
- 2022-01-27:供暖器。 冬季已经来临。 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖。 在加热器的加热半径范围内的每个房屋都可以获得供暖。 现在,给出位于一条水平线上的房屋 hous
2022-01-27:供暖器. 冬季已经来临. 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖. 在加热器的加热半径范围内的每个房屋都可以获得供暖. 现在,给出位于一条水平线上的房屋 hous ...
- ChatGPT4通道开放接入基于OPEN AI 平台你的任何APP 可一键接入AI 智能
你一定很好奇什么是 OPEN AI快速开发平台 顾名思义,开放的OPEN AI平台. 基于这个平台你的上层应用,如何 APP,小程序,H5,WEB, 公众号,任何一切终端都可以轻松接入,AI智能应用. ...
- 在使用abaqus时可能会遇到的一些问题
我收集了一些网友及客户在使用abaqus软件时遇到的一些问题,下面来看看是如何解决的~ (1)Linux平台使用Abaqus子程序的免费方案 gcc+gfortran 本方法在centos7和cen ...
- linux FTP文本传输
目录 一.文本传输协议 二.连接方式 三.程序安装 四.黑名单和白名单 五.实验 1.实验一:匿名用户下载与上传 2.实验二:关闭匿名用户登录,允许普通用户登录在家目录上传和下载 3.实验三:禁止用户 ...
- JS 数组常用操作全集
文章目录 1.push()方法 2.unshift()方法 3.pop() 方法 4.shift() 方法 5.filter() 方法 6.join()方法 7. indexOf() 方法 8.rev ...
- 《最新出炉》系列初窥篇-Python+Playwright自动化测试-1-环境准备与搭建
1.简介 有很多人私信留言宏哥问能不能介绍一下Playwright这款自动化神器的相关知识,现在网上的资料太少了.其实在各大博客和公众号也看到过其相关的介绍和讲解.要不就是不全面.不系统,要不就是系统 ...