您当前的位置:首页 > 电脑百科 > 数据库 > 百科

秒级搭建各类数据库测试环境

时间:2021-05-13 14:53:13  来源:今日头条  作者:代码狂魔

背景

试想一下这种情况,你负责的某个项目数据源有SQL Server、Oracle和MySQL,假设现在不让你访问生产库,也没有测试库给你用,你就只有一台开发电脑,要你做开发你怎么做?

你肯定会说,这问题还不简单吗?在开发电脑上安装这些数据库不就行了?答案是可以,但是偏题了嘛,你要在一台电脑上同时装SQL Server、Oracle和MySQL,能做到秒级?起码得废半天劲儿吧

话说n年前我也遇到过这种需求,必须得在我那破笔记本上装个SQL Server,装完占用硬盘10G多,用了一上午才装完,都不用干活儿了,等就完事,卸载还可能卸载不干净

我们的核心需求是搭建个测试环境,或者临时用一下,就不用过多优化,一个字,快就完事了,那么有秒级搭建的方法么?

有,下面Docker上场,docker是什么就不用过多介绍了,以前写了很多篇文章介绍,注意,docker是全平台支持的,但是如果是在非linux环境下,我建议先装个Linux虚拟机,然后在虚拟机里面装docker,这么做的原因是非Linux环境下发行的docker desktop其实也是自己内置了一个Linux虚拟机,一个手动挡,一个自动挡的区别,我建议你用自动挡,这样更清楚原理一些

如果你还没有安装docker,先装一个吧,我以前写过一篇全平台安装docker的文章【史上最全(全平台)docker安装方法!】,可以作为参考

  • windows:https://docs.docker.com/docker-for-windows/install/
  • mac OS:https://docs.docker.com/docker-for-mac/install/
  • Linux:https://docs.docker.com/engine/install/

在docker下搭建至少有两个好处

  • 快速启动
  • 资源隔离

SQLServer

dockerhub参考:
https://hub.docker.com/_/microsoft-mssql-server

这是微软官方出品的基于Ubuntu的SQL Server docker镜像,看下最新版镜像大小(2021-04-30),1.49G,真香

mcr.microsoft.com/mssql/server   latest              62c72d863950        3 weeks ago         1.49GB

秒级启动命令:

# 启动SQL Server,如果是Docker Desktop要把单引号改成双引号
docker run -e 'ACCEPT_EULA=Y' -e 'SA_PASSword=yourStrong(!)Password' -e 'MSSQL_PID=Developer' -p 1433:1433 -d --name MSSQL_1433 mcr.microsoft.com/mssql/server

# 进入容器内
docker exec -it MSSQL_1433 /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P yourStrong(!)Password

# 创建数据库
CREATE DATABASE testDB
go

然后就可以用下面这套参数连接数据库了

主机:127.0.0.1
端口:1433
数据库:testDB
用户名:sa
密码:yourStrong(!)Password

下面是环境变量的解释

  • ACCEPT_EULA:全称Accept End-User Licensing Agreement,接收最终用户许可证协议,必须得接收嘛,不然微软不给你用
  • SA_PASSWORD:全称System Administrator Password,系统管理员密码,密码必须是8位以上的大小写字母和数字/特殊符号的组合。
  • MSSQL_PID:全称Microsoft SQL Server Product Id,SQL Server的产品ID,默认是Developer

产品ID还可以是以下这些值

  • Developer : 默认值,以开发版运行
  • Express : 以学习版运行
  • Standard : 以标准版运行
  • Enterprise : 以企业版运行
  • EnterpriseCore : 以企业核心版运行

完整的环境变量可以参考此处:
https://docs.microsoft.com/en-us/sql/linux/sql-server-linux-configure-environment-variables?view=sql-server-2017

Oracle

Oracle数据库有Express Edition(精简版,简称xe)和Enterprise Edition(企业版,简称ee),xe版本我没找到任何官方的镜像,ee倒是有Oracle官方镜像,但是要使用的话必须填下面这玩意儿,emmmm,还是算了吧,这一点也不符合我们的题意:秒级

秒级搭建各类数据库测试环境

 

搜索大法好,找个评分高的镜像

docker search Oracle
NAME                            STARS
oraclelinux                     756  
jaspeen/oracle-11g              172  
oracleinanutshell/oracle-xe-11g 155
wnameless/oracle-xe-11g-r2      59
absolutApps/oracle-12c-ee       48

通过搜索发现jaspeen/oracle-11g 和
oracleinanutshell/oracle-xe-11g评分高,前者我看过了比较繁琐,也不符合我们的题意,那就
oracleinanutshell/oracle-xe-11g吧

dockerhub参考:
https://hub.docker.com/r/oracleinanutshell/oracle-xe-11g

看下下载的镜像有多大,2.13G,体积还是挺大的

oracleinanutshell/oracle-xe-11g   latest              ad13c30ec346        2 years ago         2.13GB

秒级启动命令:

# 启动Oracle 11g xe,如果是Docker Desktop要把单引号改成双引号
# ORACLE_ALLOW_REMOTE表示允许远程连接
docker run -d --name ORACLE_1521 -p 1521:1521 -e 'ORACLE_ALLOW_REMOTE=true' oracleinanutshell/oracle-xe-11g

然后就可以用下面这套参数连接数据库了

主机:127.0.0.1
端口:1521
sid:xe
用户名:system
密码:oracle

当然,一般而言不能用system账号连数据库,下面是创建账号一把梭流程

-- 创建用户myuser,密码password
create user myuser identified by password; 
-- 分配表空间权限
grant create table,unlimited tablespace to myuser;
-- 分配查询权限
grant select any table to myuser;
-- 分配增删改权限
grant update any table,drop any table,insert any table to myuser;
-- 分配创建session权限(登陆)
grant create session to myuser;

MySQL

MySQL就好说多了,官方镜像一堆一堆的,任君挑选,5.X和8.X都有

dockerhub参考:
https://hub.docker.com/_/mysql

看下下载的镜像有多大,447M和556M,不大不小

mysql                             5.7.34              87eca374c0ed        10 days ago         447MB
mysql                             8.0.24              0627ec6901db        10 days ago         556MB

秒级启动命令:

# 启动MySQL 5,如果是Docker Desktop要把单引号改成双引号
docker run --name MYSQL_3306 -p 3306:3306 -e 'MYSQL_ROOT_PASSWORD=my-secret-pw' -d mysql:5.7.34

如果需要MySQL 8.X,直接改tag就可以了

# 启动MySQL 8,如果是Docker Desktop要把单引号改成双引号
docker run --name MYSQL_3306 -p 3306:3306 -e 'MYSQL_ROOT_PASSWORD=my-secret-pw' -d mysql:8.0.24

然后就可以用下面这套参数连接数据库了

主机:127.0.0.1
端口:3306
数据库:(可为空)
用户名:root
密码:my-secret-pw

PostgreSQL

dockerhub参考:
https://hub.docker.com/_/postgres

秒级启动命令:

# 启动PostgreSQL,如果是Docker Desktop要把单引号改成双引号
docker run --name POSTGRES_5432 -p 5432:5432 -e 'POSTGRES_PASSWORD=mysecretpassword' -d postgres

然后就可以用下面这套参数连接数据库了

主机:127.0.0.1
端口:5432
数据库:(可为空)
用户名:postgres
密码:mysecretpassword


Tags:数据库测试   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
背景试想一下这种情况,你负责的某个项目数据源有SQL Server、Oracle和MySQL,假设现在不让你访问生产库,也没有测试库给你用,你就只有一台开发电脑,要你做开发你怎么做?你肯定会说,...【详细内容】
2021-05-13  Tags: 数据库测试  点击:(191)  评论:(0)  加入收藏
▌简易百科推荐
1增1.1【插入单行】insert [into] <表名> (列名) values (列值)例:insert into Strdents (姓名,性别,出生日期) values (&#39;开心朋朋&#39;,&#39;男&#39;,&#39;1980/6/15&#3...【详细内容】
2021-12-27  快乐火车9d3    Tags:SQL   点击:(1)  评论:(0)  加入收藏
最近发现还有不少做开发的小伙伴,在写存储过程的时候,在参考已有的不同的写法时,往往很迷茫, 不知道各种写法孰优孰劣,该选用哪种写法,以及各种写法的优缺点,本文以一个简单的查询...【详细内容】
2021-12-23  linux上的码农    Tags:sql   点击:(9)  评论:(0)  加入收藏
《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的HasorDB 是一个全功能数据库访问工具,提供对象映射、丰...【详细内容】
2021-12-22  GitHub精选    Tags:HasorDB   点击:(5)  评论:(0)  加入收藏
作者丨Rafal Grzegorczyk译者丨陈骏策划丨孙淑娟【51CTO.com原创稿件】您是否还在手动对数据库执行各种脚本?您是否还在浪费时间去验证数据库脚本的正确性?您是否还需要将...【详细内容】
2021-12-22    51CTO  Tags:Liquibase   点击:(3)  评论:(0)  加入收藏
场景描述:由于生产环境的表比较复杂,字段很多。这里我们做下简化,只为说明今天要聊的问题。有两张表 tab1,tab2: tab1 数据如下: tab2 数据如下: 然后给你看下,我用来统计 name=&#3...【详细内容】
2021-12-20  Bald    Tags:SQL   点击:(5)  评论:(0)  加入收藏
前言知识无底,学海无涯,知识点虽然简单,但是比较多,所以将MySQL的基础写出来,方便自己以后查找,还有就是分享给大家。一、SQL简述1.SQL的概述Structure Query Language(结构化查...【详细内容】
2021-12-16  谣言止于独立思考    Tags:SQL基础   点击:(13)  评论:(0)  加入收藏
前言作为一名测试工程师,工作中在对测试结果进行数据比对的时候,或多或少要和数据库打交道的,要和数据库打交道,那么一些常用的 SQL 查询语法必须要掌握。最近有部分做测试小伙...【详细内容】
2021-12-14  柠檬班软件测试    Tags:SQL   点击:(15)  评论:(0)  加入收藏
话说C是面向内存的编程语言。数据要能存得进去,取得出来,且要考虑效率。不管是顺序存储还是链式存储,其寻址方式总是很重要。顺序存储是连续存储。同质结构的数组通过其索引表...【详细内容】
2021-12-08  小智雅汇    Tags:数据存储   点击:(17)  评论:(0)  加入收藏
概述DBConvert Studio 是一款强大的跨数据库迁移和同步软件,可在不同数据库格式之间转换数据库结构和数据。它将成熟、稳定、久经考验的 DBConvert 和 DBSync 核心与改进的现...【详细内容】
2021-11-17  雪竹聊运维    Tags:数据库   点击:(26)  评论:(0)  加入收藏
一、前言 大家好,我是小诚,《从0到1-全面深刻理解MySQL系列》已经来到第四章,这一章节的主要从一条SQL执行的开始,由浅入深的解析SQL语句由客户端到服务器的完整执行流程,最...【详细内容】
2021-11-09  woaker    Tags:SQL   点击:(35)  评论:(0)  加入收藏
相关文章
    无相关信息
最新更新
栏目热门
栏目头条