构建Mysql容器

1、拉取mysql镜像

docker pull mysql/mysql-server

2、创建mysql镜像

docker run -d -p 3306:3306 -e MYSQL_USER="lzl" -e MYSQL_PASSWORD="password" -e MYSQL_ROOT_PASSWORD="password" --name mysql01 mysql/mysql-server --character-set-server=utf8 --collation-server=utf8_general_ci

3、进入mysql 授权给上面用户"lzl"权限

①docker exec -it mysql01 bash

②mysql -uroot -p

③GRANT ALL PRIVILEGES ON . TO 'LZL'@'%' WITH GRANT OPTION;

构建.NetCoreApi

一、新建api项目

二、安装mysql驱动

MySql.Data.EntityFrameworkCore 8.0.18连接.netCore3.0 有Bug ,做Db迁移的时候失败.因此采用Pomelo.EntityFrameworkCore.MySql驱动。

Microsoft.EntityFrameworkCore.tools。

三、新建Model、配置DbContext

①新建文件夹Entityes、新建User

namespace Api.Entities
{
public class User
{
public int Id { get; set; } public string Name { get; set; } public string Company { get; set; } public string Title { get; set; }
} }

②新建文件夹Data、新建UserContext.cs

namespace Api.Data
{
public class UserContext:DbContext
{
public UserContext(DbContextOptions<UserContext> options):base(options)
{ } protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<User>()
.ToTable("t_ApiUser");
} public DbSet<User> Users { get; set; }
} }

四、配置UserContext DI注入、配置MYSQL链接字符串

public void ConfigureServices(IServiceCollection services)
{
services.AddDbContext<UserContext>(options =>
{
options.UseMySql(Configuration.GetConnectionString("MySqlConString"));
});
services.AddControllers();
}
"ConnectionStrings": {
"MySqlConString": "Server=mysql01;database=db_appuser;userid=lzl;password=password;"
}

注意:此处Server=mysql01为第一步Mysql容器的名称。在本地开发的时候可以设置为对应的Db服务器地址。

五、初始化Db

依次执行 Add-Migration IntialDb、Update-Database

六、添加SeedData

StartUp.cs添加以下代码初始化数据。

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseHttpsRedirection(); app.UseRouting(); app.UseAuthorization(); app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
}); InitialDataBase(app);
} public void InitialDataBase(IApplicationBuilder app)
{
using (var scope = app.ApplicationServices.CreateScope())
{
var context = scope.ServiceProvider.GetRequiredService<UserContext>(); if (!context.Users.Any())
{
context.Users.Add(new User()
{
Company = "kingdee",
Name = "LZL",
Title = "2020",
Id = 1
});
context.SaveChanges();
}
}
}

七、新建UserController

namespace Api.Controllers
{
[ApiController]
[Route("[controller]/[action]")]
public class UserController : ControllerBase
{
private ILogger<UserController> _logger;
private UserContext _userContext;
public UserController(ILogger<UserController> logger,UserContext userContext)
{
_logger = logger;
_userContext = userContext;
} [HttpGet]
public async Task<IActionResult> Get()
{
var users = await _userContext.Users.ToListAsync();
return new JsonResult(users);
}
} }

八、启动项目,测试连接是否成功

九、编写api的Dockerfile

# 1.指定编译和发布应用的镜像

FROM mcr.microsoft.com/dotnet/core/sdk:3.0 AS build-env

# 2. 指定(编译和发布)工作目录

WORKDIR /app

# 3. 拷贝.csproj到工作目录/app,然后执行dotnet restore恢复所有安装的NuGet包

COPY *.csproj ./
RUN dotnet restore # 4. 拷贝当前项目目录下所有文件到工作目录(/app),然后执行dotnet publish命令将应用发布到/app/out目录下 COPY . ./
RUN dotnet publish -c Release -o out # 5. 编译生成Docker镜像 # 5.1.设置基础镜像 FROM mcr.microsoft.com/dotnet/core/aspnet:3.0 AS runtime # 5.2. 设置(运行)工作目录,并将发布文件拷贝到out子目录下 WORKDIR /app
COPY --from=build-env /app/out . # 5.3. 利用环境变量设置ASP.NET Core应用的监听地址 ENV ASPNETCORE_URLS http://0.0.0.0:3827 # 5.4. 执行dotnet命令启动ASP.NET Core应用 ENTRYPOINT ["dotnet", "Api.dll"]

10、cmd进入项目的dos目录、构建api镜像

docker build -t userapi:prod .

-t 镜像名称 dockerfile所在的目录

11、创建network,用于连接mysql容器和api容器

docker network create -d bridge my-network

-d 参数指定 Docker 网络类型,有 bridge overlay。其中 overlay 网络类型用于 Swarm mode

12、创建启动api容器,指定对应的network

docker run -d -p 8084:3827 --network my-net --name myuserapi userapi:prod

本机端口8084,容器监听端口3827

13、由于mysql01容器并没有加入到该网络连接,api容器依然无法访问。下面将mysql01添加到my-net中来

docker network connect my-net mysql01  #添加进网络

docker network disconnect my-net mysql01 #从网络中移除

14、查看两个容器是否在同一网段

docker inspect myuserapi

docker inspect mysql01

15、浏览器访问localhost:8084/User/Get。

docker中netcoreapi连接Mysql成功

.NetCoreApi容器与MySql容器互联的更多相关文章

  1. docker 安装tomcat容器和mysql容器

    1. docker pull mysql:5.6 2.docker run -p 3306:3306 --name mysql -v /data/mysql/conf:/etc/mysql/conf. ...

  2. docker容器互联 (.net core容器,mysql容器)

    背景 有两个容器一个运行的.net core的项目 另一个运行的mysql的数据 并且这两个容器在同一个机子上(或者局域网),那么理论上.net core的项目去访问mysql是可以走内网的 但是容器 ...

  3. asp.net core容器&mysql容器network互联 & docker compose方式编排启动多个容器

    文章简介 asp.net core webapi容器与Mysql容器互联(network方式) docker compose方式编排启动多个容器 asp.net core webapi容器与Mysql ...

  4. Java开源博客My-Blog之mysql容器重复初始化的严重bug修复过程

    写在前面的话 <Docker+SpringBoot+Mybatis+thymeleaf的Java博客系统开源啦> <Java开源博客My-Blog之docker容器组件化修改> ...

  5. docker:从 tomcat 容器连接到 mysql 容器

    docker 中的容器互联是一个较为复杂的话题,详细内容将在后续章节中介绍. 续前 2 个章节的内容,我们创建了一个 mysql 容器和一个 tomcat 容器,可以使用 「docker ps」来查看 ...

  6. docker学习笔记4:利用docker hub上的mysql镜像创建mysql容器

    docker hub上有官方的mysql镜像,我们可以利用它来创建mysql容器,作为一个服务容器使用. 1.下载mysql镜像 docker pull mysql 2.创建镜像 docker run ...

  7. docker 容器的mysql主从复制

    一. 1.首先拉取docker镜像,我们这里使用5.7版本的mysql:   docker pull mysql:5.7 2.分别启动主从两个容器: docker run -p 3339:3306 - ...

  8. 使用docker容器运行MySQL数据库并持久化数据文件

    1.下载mysql镜像 # docker pull mysql 2.启动mysql容器 # docker run -itd -v /data:/var/lib/mysql -p 33060:3306 ...

  9. Docker搭建Mysql容器

    转载自:http://blog.csdn.net/Mungo/article/details/78521832?locationNum=9&fps=1 本文介绍如何使用docker迅速搭建My ...

随机推荐

  1. JAVA内存溢出解析(转)

    JAVA内存溢出解析(转) 核心提示:原因有很多种,比如: 1.数据量过于庞大:死循环 :静态变量和静态方法过多:递归:无法确定是否被引用的对象: 2.虚拟机不回收内存(内存泄漏): 说白了就是程序运 ...

  2. Libev源码分析08:Libev中的信号监视器

    Libev中的信号监视器,用于监控信号的发生,因信号是异步的,所以Libev的处理方式是尽量的将异步信号同步化.异步信号的同步化方法主要有:signalfd.eventfd.pipe.sigwaiti ...

  3. 【转载】字符编码笔记:ASCII,Unicode和UTF-8

    字符编码笔记:ASCII,Unicode和UTF-8 作者: 阮一峰 今天中午,我突然想搞清楚Unicode和UTF-8之间的关系,于是就开始在网上查资料. 结果,这个问题比我想象的复杂,从午饭后一直 ...

  4. 【[Offer收割]编程练习赛15 A】 偶像的条件

    [题目链接]:http://hihocoder.com/contest/offers15/problem/1 [题意] [题解] 把3个数组的元素全都合并在一个数组里面; (当然你要记录每个数字原本是 ...

  5. shell Usage

    Usage(){ cat <<EOF Usage: $ [tenant] $ (Run database table check_table_data_config all tenants ...

  6. docker + jenkins 自动化部署

    公司书架上有本docker的书籍,正好最近事不多就写个demo来玩一玩. DevOps未死,ContainerOps已到 ContainerOps VS DevOps 避免了复杂的环境,应用之间的相互 ...

  7. 【BestCoder Round #93 1004】MG loves set

    [题目链接]:http://acm.hdu.edu.cn/showproblem.php?pid=6022 [题意] 让你求一个集合的子集数目; 这个子集有要求; 即: 它所有元素的平方的和小于它所有 ...

  8. Git上传本地项目到码云

    前提:本地安装git.注册码云 1.进入本地项目文件夹,鼠标右键代开 Git Bash Here 2.输入命令 初始化库管理文件 git init 3.输入命名 修改Git的全局配置 git conf ...

  9. Java语法格式

    任何一种语言都有自己的语法规则,Java也一样,既然是规则,那么知道其如何使用就可以了. 代码都定义在类中,类由class来定义,区分 public class  和  class; 代码严格区分大小 ...

  10. windows命令行下redis读取中文字符乱码

    我在eclipse上对redis进行了一个操作,添加了一个中文字符串进去,可以看到是添加成功了的 但是在命令行中读取的时候却成了乱码,如下图所示 这是因为windows命令行的编码是gbk 可以通过如 ...