dockerdesktop 制作asp.net core webapi镜像-连接sqlserver数据库容器

本文主要是介绍dockerdesktop 制作asp.net core webapi镜像-连接sqlserver数据库容器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.使用visual studio 创建 asp.net core webapi项目
在这里插入图片描述
选择启用docker 会生成Dockerfile文件
2.使用efcore连接数据库,安装efcore的包

  <ItemGroup><PackageReference Include="Microsoft.VisualStudio.Azure.Containers.Tools.Targets" Version="1.18.1" /><PackageReference Include="Swashbuckle.AspNetCore" Version="6.2.3" /><PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="6.0.10" /><PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="6.0.0"><PrivateAssets>all</PrivateAssets><IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets></PackageReference></ItemGroup>

3.实体类和数据库对应

using Microsoft.EntityFrameworkCore;
using System.ComponentModel.DataAnnotations;namespace WebApplication4
{public class Inventory{[Key]public int id { get; set; }public string name { get; set; }public int quantity { get; set; }}
}

4.配置数据库连接字符串
//Data Source用的是容器里面的数据库容器名,这里需要容器之间通讯

{"Logging": {"LogLevel": {"Default": "Information","Microsoft.AspNetCore": "Warning"}},"AllowedHosts": "*","ConnectionStrings": {"DefaultConnection": "Data Source=sql-server2022;Database=TestDB;User Id=SA;Password=123456;"}
}

5.创建数据库上下文

using Microsoft.EntityFrameworkCore;namespace WebApplication4
{public class AppDbContext : DbContext{public AppDbContext(DbContextOptions<AppDbContext> options): base(options){}protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder){//optionsBuilder.UseSqlServer("server=localhost,1400;uid=SA;pwd=peng@123;database=TestDB");}public DbSet<Inventory> Inventory { get; set; }}
}

6.业务代码

namespace WebApplication4
{public interface Iservice{void add(Inventory inventory);void remove(int id);List<Inventory> Getlsit();}
}
namespace WebApplication4
{public class service : Iservice{private readonly AppDbContext _context;public service(AppDbContext context){_context = context;}public void add(Inventory inventory){_context.Inventory.Add(inventory);_context.SaveChanges();}public List<Inventory> Getlsit(){return _context.Inventory.ToList();}public void remove(int id){var ENRTY = _context.Inventory.FirstOrDefault(p => p.id == id);_context.Inventory.Remove(ENRTY);_context.SaveChanges();}}
}

7.注入服务

using Microsoft.EntityFrameworkCore;namespace WebApplication4
{public class Program{public static void Main(string[] args){var builder = WebApplication.CreateBuilder(args);// Add services to the container.builder.Services.AddControllers();// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbucklebuilder.Services.AddEndpointsApiExplorer();builder.Services.AddScoped<Iservice, service>();builder.Services.AddDbContext<AppDbContext>(options =>options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));builder.Services.AddSwaggerGen();var app = builder.Build();//注释可以在生产环境看到swagger页面// Configure the HTTP request pipeline.//if (app.Environment.IsDevelopment())//{app.UseSwagger();app.UseSwaggerUI();//}app.UseAuthorization();app.MapControllers();app.Run();}}
}

8.contrllor代码

using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;namespace WebApplication4.Controllers
{[Route("api/[controller]")][ApiController]public class InveryController : ControllerBase{private readonly Iservice iservice;public InveryController(Iservice iservice){this.iservice = iservice;}[HttpGet]public IActionResult Getlist(){return new JsonResult(iservice.Getlsit());}[HttpPost]public IActionResult Add([FromBody] Inventory inventory){iservice.add(inventory);return Ok("add success");}[HttpDelete("{id}")]public IActionResult delete(int id){iservice.remove(id);return Ok("remove success");}}
}

9.编写dockerfile文件
在这里插入图片描述
根据自己的项目信息更改

#获取asp.net6的镜像
FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
#创建工作目录
WORKDIR /app
#复制当前目录到工作目录
ADD . /app
#开放端口
EXPOSE 5999
CMD ["--urls","http://0.0.0.0:5999"]
#设置环境变量
ENTRYPOINT ["dotnet", "WebApplication4.dll"]

10.发布项目
在这里插入图片描述
11.切换到发布文件目录 终端打开
在这里插入图片描述
12.添加网络(不添加容器间无法通讯)

 docker network create mynetwork#sql-server2022(数据库容器)docker network connect mynetwork   sql-server2022 

13.构建镜像

docker build -t webapplication4 -f ./Dockerfile .

在这里插入图片描述

13.运行容器(把容器加到添加的网络里)
-d 后台运行
–name 容器的名字
-p 端口映射
–network 网桥名称
webapplication4 镜像的名称

docker run -d  --name webapiTest -p 5999:5999 --network=mynetwork webapplication4

在这里插入图片描述

14.查看运气是否运行

docker ps

在这里插入图片描述
15.在浏览器里运行(点击进入浏览器)
在这里插入图片描述
在网址里加上 /swagger/index.html
在这里插入图片描述
就可以访问数据了。
注意:如果访问的数据库不在docker容器里面就直接写ip地址就行,如果做了端口映射,数据库连接要127.0.0.1,1434 这样的形式。
end…

这篇关于dockerdesktop 制作asp.net core webapi镜像-连接sqlserver数据库容器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/461168

相关文章

Linux搭建单机MySQL8.0.26版本的操作方法

《Linux搭建单机MySQL8.0.26版本的操作方法》:本文主要介绍Linux搭建单机MySQL8.0.26版本的操作方法,本文通过图文并茂的形式给大家讲解的非常详细,感兴趣的朋友一起看看吧... 目录概述环境信息数据库服务安装步骤下载前置依赖服务下载方式一:进入官网下载,并上传到宿主机中,适合离线环境

MySQL主从同步延迟问题的全面解决方案

《MySQL主从同步延迟问题的全面解决方案》MySQL主从同步延迟是分布式数据库系统中的常见问题,会导致从库读取到过期数据,影响业务一致性,下面我将深入分析延迟原因并提供多层次的解决方案,需要的朋友可... 目录一、同步延迟原因深度分析1.1 主从复制原理回顾1.2 延迟产生的关键环节二、实时监控与诊断方案

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

MySQL 多表连接操作方法(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL OUTER JOIN)

《MySQL多表连接操作方法(INNERJOIN、LEFTJOIN、RIGHTJOIN、FULLOUTERJOIN)》多表连接是一种将两个或多个表中的数据组合在一起的SQL操作,通过连接,... 目录一、 什么是多表连接?二、 mysql 支持的连接类型三、 多表连接的语法四、实战示例 数据准备五、连接的性

MySQL中的分组和多表连接详解

《MySQL中的分组和多表连接详解》:本文主要介绍MySQL中的分组和多表连接的相关操作,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录mysql中的分组和多表连接一、MySQL的分组(group javascriptby )二、多表连接(表连接会产生大量的数据垃圾)MySQL中的

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

Windows 上如果忘记了 MySQL 密码 重置密码的两种方法

《Windows上如果忘记了MySQL密码重置密码的两种方法》:本文主要介绍Windows上如果忘记了MySQL密码重置密码的两种方法,本文通过两种方法结合实例代码给大家介绍的非常详细,感... 目录方法 1:以跳过权限验证模式启动 mysql 并重置密码方法 2:使用 my.ini 文件的临时配置在 Wi

MySQL重复数据处理的七种高效方法

《MySQL重复数据处理的七种高效方法》你是不是也曾遇到过这样的烦恼:明明系统测试时一切正常,上线后却频频出现重复数据,大批量导数据时,总有那么几条不听话的记录导致整个事务莫名回滚,今天,我就跟大家分... 目录1. 重复数据插入问题分析1.1 问题本质1.2 常见场景图2. 基础解决方案:使用异常捕获3.