Docker实战(九)之数据库应用

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: 目前,主流数据库包括关系型和非关系型两种。关系型数据库是建立在关系模型基础上的数据库,借助于集合代数等数学概念金额方法来处理数据库中的数据,支持复杂的事务处理和结构化查询。代表实现有MySQL、Oracle、PostGreSQL、MariaDB、SQLServer等。

目前,主流数据库包括关系型和非关系型两种。

关系型数据库是建立在关系模型基础上的数据库,借助于集合代数等数学概念金额方法来处理数据库中的数据,支持复杂的事务处理和结构化查询。代表实现有MySQL

、Oracle、PostGreSQL、MariaDB、SQLServer等。

非关系型数据库是新兴的数据库技术,它放弃了传统关系型数据库的部分强一限制,带来性能上的提升,使其更适用于需要大规模并行处理订单场景。非关系型数据库是关系型数据库的补充,代表产品有MongoDB、Redis、CouchDB等。

 

1.MySQL

使用官方镜像可与快速启动一个MySQL Server实例,如下所示:

docker run --name hi-mysql -e MYSQL_ROOT_PASSWORD=123 -d mysql:latest

 

当然,还可以使用--link标签将一个应用容器连接到MySQL容器:

docker run --name some-app --link some-mysql:mysql -d application-that-uses-mysql

 

(1)系统与日志访问

docker exec -it some-mysql bash

MySQL日志可以使用docker logs指令查看:

docker logs some-mysql

(2)使用自定义配置文件

如果用户希望使用自定义MySQL配置,则可以创建一个目录,内置cnf配置文件,然后将其挂载至容器的/etc/mysql/conf.d目录。比如,自定义配置文件为/my/custom/config-file.conf,则可以使用以下指令:

docker run --name some-mysql -v /my/custom:/etc/mysql/conf.d -e MySQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

这是新的容器some-mysql启动后,就会结合/etc/mysql/my.cnf和/etc/mysql/conf.d/config-file.cnf两个配置文件。

(3)脱离cnf文件进行配置

很多配置选项可以通过标签(flags)传递至mysqld进程。这样用户就可以脱离cnf配置文件,对容器进行弹性定制。比如,用户需要改变默认编码方式,将所有表格额的编码改为ut8mb4,则可以使用以下指令:

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

如果需要查看可用选项的完整列表,可以执行:

docker run -it --rm mysql:tag --verbose --help

 

2.MongoDB

MongoDB是一款可扩展,高性能的开源文档数据库,是当今最流行的NoSQL数据库之一。它采用C++开发,支持复杂的数据类型和强大的查询语言,提供了关系数据库的绝大部分功能。由于MongoDB高性能、易部署、易使用等特点,已经在很多领域都很多应用。

(1)使用官方镜像

docker run --name mongo-container -d mongo

docker exec -it 942be12b8418 sh

进入mongodb数据库界面

mongo显示相关版本信息

 

show dbs显示所有库

 

db.status()查看数据库状态

 

通过该命令 docker exec -it 942be12b8418 /bin/bash进入容器

镜像默认暴露mongodb的服务端口:27017,可以通过该端口访问服务。

(1)连接mongodb容器

使用--link参数,连接新建的mongo-container容器

docker run -it --link mongo-container:db alpine sh

进入alpine系统容器后,用户可以通过ping指令测试mongo容器的连通性:

ping db

 

(2)直接使用mongo cli指令

如果想直接在宿主机器上使用mongodb镜像,可以在docker run指令后面加入entrypoint指令,这样就可以非常方便的直接进入mongo cli了。

docker run -it --link mongo-container:db --entrypoint mongo mongo --host db

 

3.Redis

Redis是一个开源的基于内存的数据结构存储系统,可以用作数据库、缓存和消息中间件。

使用官方镜像

 docker run --name redis-container -d redis

(1)连接redis容器

docker run -it --link redis-container:db alpine sh

 官方镜像内也自带了redis客户端,可以使用以下指令直接使用:

docker run -it --link redis-container:db --entrypoint redis-cli redis -h db

(2)使用自定义配置

docker run -v /myredis/conf/redis.conf:/usr/local/etc/redis/redis.conf --name myredis redis redis-server /usr/local/etc/redis/redis.conf

 

4.Memcached

Memcached是一个高性能、分布式的开源内存对象缓存系统。最初是Danga Interactive为了优化LiveJournal的访问速度而编写的。目前已经非常广泛的应用于各种Web应用。以BSD licenses授权协议发布。

Memcached守护进程基于C语言实现,基于libevent的事件处理可以实现很高的性能。需要注意的是,由于数据仅存在于内存中,因此重启Memcached或重启操作系统会导致数据全部丢失。

可以直接通过官方提供的memcached镜像运行一个memcached-container容器:

docker run --name memcached-container -d memcached

以下指令会将memcached server的内存使用量设置为64MB。

docker run --name memcached-container-2 -d memcached memcached -m 64

5.CouchDB

CouchDB是一款面向文档的NoSQL数据库,以JSON格式存储数据。它兼容ACID,可以用于存储网站的数据与内容,以及提供缓存等。CouchDB里文档域都是以键值对的形式存储,对数据的每次修改都会得到一个新的文档修订号。

CouchDB侧重于API(可用性和分区容忍度)。相比之下,MongoDB侧重于CP(一致性和分区容忍度),Neo4j则提供了特有的面向图形的结构。

运行官方镜像:

docker run --name couchdb-container couchdb
这个镜像中CouchDB的默认端口是5984,用户可以使用link指令进行容器链接:

docker run --name couchdb-app --link couchdb-container:couch couchdb

 

6.Cassandra

Cassandra是个开源的分布式数据库,支持分散的数据存储,可以实现容错以及无单点故障等。Cassandra在设计上引入了P2P技术,具备大规模可分区行存储能力,并支持Spark、Storm、Hadoop的集成。目前Facebook、Twitter、Instagram、eBay、Github等多家公司都在使用Cassandra。类似的工具还有Hbase等。

使用官方镜像

docker run --name my-cassandra -d cassandra:latest

这里的--name标签指定容器名称。cassandra:tag的标签指定版本号。标签名称可以参考官方仓库的标签说明:https://hub.docker.com/r/library/cassandra/tags。

 

目录
相关文章
|
3月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
791 108
|
1月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
288 7
|
1月前
|
存储 人工智能 NoSQL
AI大模型应用实践 八:如何通过RAG数据库实现大模型的私有化定制与优化
RAG技术通过融合外部知识库与大模型,实现知识动态更新与私有化定制,解决大模型知识固化、幻觉及数据安全难题。本文详解RAG原理、数据库选型(向量库、图库、知识图谱、混合架构)及应用场景,助力企业高效构建安全、可解释的智能系统。
|
人工智能 关系型数据库 OLAP
聚光灯已就位!阿里云瑶池数据库邀你征战Cursor首届实战征文大赛
阿里云AnalyticDB携手Cursor中文社区,正式发起首届实战征文大赛!我们诚邀开发者融合Cursor的智能编程能力与AnalyticDB PostgreSQL提供的Supabase服务进行项目开发,让优秀项目被专家看见、被机遇拥抱!
|
1月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
2月前
|
前端开发 JavaScript 应用服务中间件
在Docker部署的前端应用中使用动态环境变量
以上步骤展示了如何在 Docker 配置过程中处理并注入环墨遁形成可执行操作流程,并确保最终用户能够无缝地与之交互而无须关心背后复杂性。
179 13
|
2月前
|
存储 弹性计算 Cloud Native
云原生数据库的演进与应用实践
随着企业业务扩展,传统数据库难以应对高并发与弹性需求。云原生数据库应运而生,具备计算存储分离、弹性伸缩、高可用等核心特性,广泛应用于电商、金融、物联网等场景。阿里云PolarDB、Lindorm等产品已形成完善生态,助力企业高效处理数据。未来,AI驱动、Serverless与多云兼容将推动其进一步发展。
187 8
|
2月前
|
存储 数据库 开发者
Python SQLite模块:轻量级数据库的实战指南
本文深入讲解Python内置sqlite3模块的实战应用,涵盖数据库连接、CRUD操作、事务管理、性能优化及高级特性,结合完整案例,助你快速掌握SQLite在小型项目中的高效使用,是Python开发者必备的轻量级数据库指南。
280 0
|
2月前
|
存储 弹性计算 安全
现有数据库系统中应用加密技术的不同之处
本文介绍了数据库加密技术的种类及其在不同应用场景下的安全防护能力,包括云盘加密、透明数据加密(TDE)和选择列加密。分析了数据库面临的安全威胁,如管理员攻击、网络监听、绕过数据库访问等,并通过能力矩阵对比了各类加密技术的安全防护范围、加密粒度、业务影响及性能损耗。帮助用户根据安全需求、业务改造成本和性能要求,选择合适的加密方案,保障数据存储与传输安全。
|
3月前
|
存储 人工智能 数据库
视图是什么?为什么要用视图呢?数据库视图:定义、特点与应用
本文三桥君深入探讨数据库视图的概念与应用,从定义特点到实际价值全面解析。视图作为虚拟表具备动态更新、简化查询、数据安全等优势,能实现多角度数据展示并保持数据库重构的灵活性。产品专家三桥君还分析了视图与基表关系、创建维护要点及性能影响,强调视图是提升数据库管理效率的重要工具。三桥君通过系统讲解,帮助读者掌握这一常被忽视却功能强大的数据库特性。
978 0