Logo

dev-resources.site

for different kinds of informations.

Containerize ASP.NET Core API, Entity Framework with SQL Server, Let's Encrypt, Docker, and Nginx (Part 1)

Published at
11/21/2024
Categories
docker
aspnet
nginx
tutorial
Author
quocbahuynh
Categories
4 categories in total
docker
open
aspnet
open
nginx
open
tutorial
open
Author
11 person written this
quocbahuynh
open
Containerize ASP.NET Core API, Entity Framework with SQL Server, Let's Encrypt, Docker, and Nginx (Part 1)

To be honest, finding a comprehensive solution online for setting up Docker, ASP.NET Core, SQL Server, Let's Encrypt, and Nginx all together is like searching for a needle in a haystack. After hours of Googling and plenty of frustration, I decided to write down everything I learned and make life easier for everyone. Ready to get started?

How it works?

The idea is to containerize ASP.NET Core, SQL Server, Let's Encrypt, and Nginx using Docker and deploy it to an Ubuntu VPS. You can still manage the database via Azure Data Studio or SQL Server Management Studio. HTTPS will be enabled for free using Let's Encrypt, with a 3-month certificate renewal.

In this article, I'll guide you through containerizing an ASP.NET Core API with SQL Server. We'll start by setting up Entity Framework Core with Code First, then move on to configuring the containers, and add Nginx and SSL later.

Step 1: Dockerfile for ASP.NET

First, create a Dockerfile for ASP.NET. Itโ€™s simple to do in Microsoft Visual Studio. Even if you have multiple projects in your solution, just right-click on the main project, select Add > Docker Support, you can follow this article.

Image description

Step 2: Set Up Docker-Compose
Now that youโ€™ve created the Dockerfile for your ASP.NET Core, the next step is to set up docker-compose to connect your application with the SQL Server database inside the container.

version: '3.4'

services:
  sqldb:
    image: mcr.microsoft.com/mssql/server:2019-latest
    environment:
      - SA_PASSWORD=your-password
      - ACCEPT_EULA=Y
    ports:
      - "8002:1433"
    restart: always
    volumes:
      #- sql_data:/var/opt/mssql 
    networks:
      - quochuynhwebsite-network

  quochuynhwebsite:
    image: ${DOCKER_REGISTRY-}quochuynhwebsite
    build:
      context: .
      dockerfile: QuocHuynhWebsite/Dockerfile
    ports:
      - "8003:80"
    expose:
      - "5000"
    environment:
      - ASPNETCORE_URLS=http://+:5000
    networks:
      - quochuynhwebsite-network
    restart: always

networks:
  quochuynhwebsite-network:
    driver: bridge
Enter fullscreen mode Exit fullscreen mode

Important notes: Make sure your database is running before starting your application. Avoid using volumes on your local machine, as they may conflict with your local database. Also, don't forget to configure the network to ensure proper communication between the containers.

Step 3: Update Connection String in appsettings.json

After setting docker-compose file, update the connection string in appsettings.json to match the database configuration inside Docker. Since the database is running in a Docker container, youโ€™ll use the service name (sqldb) as the Server value in your connection string.

Server: sqldb
UserId: sa

"ConnectionStrings": {
    "sqlConnection": "Server=sqldb;Database=DbName;User Id=sa;Password=yourpassword;TrustServerCertificate=True;"
},
Enter fullscreen mode Exit fullscreen mode

Step 4: Setting up Entity Framework Core with Code First

If you think everything will run perfectly, you might be mistaken. The issue arises when you use Entity Framework to create the database from your classes via command line commands like add-migration and update-database. These commands are typically run using the .NET CLI, which means you'll need to create an additional image in your docker-compose setup. Is it necessary? No, you can use Entity Framework's built-in functionality to automatically create the database and tables on the first request, saving you the extra step of managing migrations manually.

Automating Database Creation with Entity Framework in ASP.NET Core

When deploying an ASP.NET Core application with Entity Framework, ensuring your database is created and tables are ready on the first run can save a lot of time and hassle. While migrations and CLI commands are often used, you can automate this process directly in your DbContext constructor.

public RepositoryContext(DbContextOptions options) : base(options)
{
    try
    {
        var databaseCreator = Database.GetService<IDatabaseCreator>() as RelationalDatabaseCreator;
        if (databaseCreator != null)
        {
            // Create the database if it doesn't exist
            if (!databaseCreator.CanConnect())
            {
                databaseCreator.Create();
            }

            // Create tables if they don't exist
            if (!databaseCreator.HasTables())
            {
                databaseCreator.CreateTables();
            }
        }
    }
    catch (Exception ex)
    {
        Console.WriteLine($"Database creation failed: {ex.Message}");
    }
}

Enter fullscreen mode Exit fullscreen mode

Now, let's access our ASP.NET Core Application:

docker-compose up --build 

// url: http://localhost:8003
Enter fullscreen mode Exit fullscreen mode

But, how I can access my database? Oke Let me teach you:
Server name: localhost,8002
Authentication: SQL Server Authantication
Login: sa
Password: your password

Image description

Conclusion

Congratulations! Youโ€™ve successfully set up your ASP.NET Core application with SQL Server in Docker. By following these steps, you've containerized your app, configured Entity Framework for automated database creation, and established connectivity between your API and the SQL Server database.
But weโ€™re not stopping here. To make your application production-ready, itโ€™s crucial to implement secure HTTPS access. This is where Nginx and Letโ€™s Encrypt SSL come into play.

Let's connect

Email: [email protected]
Website: https://www.quochuynh.website

aspnet Article's
30 articles in total
Favicon
The Future of ASP.NET: What to Expect
Favicon
DevExpress - Enhancing ASP.NET Web Forms with the ASPxGridView Control
Favicon
Advanced Search in .NET with Elasticsearch(Full Video)
Favicon
Introducing Brick SaaS Starter Kit - Launch SaaS Products Faster
Favicon
Using server sent events in ASP.NET
Favicon
Important Links
Favicon
Serverless OAuth2/OIDC server with OpenIddict 6 and RDS Aurora v2
Favicon
Learning in Reverse: How I Would Learn ASP. Net Core and Entity Framework If I Could Go Back In Time
Favicon
Dependency injection validation error in ASP.NET Core projects
Favicon
Agrupamiento de datos de una lista usando LINQ en C#
Favicon
Asp .Net: Create a Simple 'Web User Control'
Favicon
[ASP.NET] ๅฆ‚ไฝ•ๅฐŽๅ‘ๅˆฐ้Œฏ่ชค้ ้ข
Favicon
DevExpress - Simplifying Server-to-Client Data Transfer with ASPxCallback JSProperties
Favicon
Asp.net
Favicon
[ASP.NET] ่จญ็ฝฎ่ˆ‡ๅ–ๅพ— Web.config ่‡ชๅฎš็พฉ่ณ‡ๆ–™
Favicon
How to Hire Dedicated .NET Developers
Favicon
Permission-Based Authorization in ASP.NET Core: A Step-by-Step Guide
Favicon
Permission-Based Authorization in ASP.NET Core: A Step-by-Step Guide
Favicon
Dependency Container and Services Lifetimes (ะะฐ ั€ัƒััะบะพะผ)
Favicon
Containerize ASP.NET Core API, Entity Framework with SQL Server, Let's Encrypt, Docker, and Nginx (Part 1)
Favicon
differences of Transient and scoped in ASP NET
Favicon
ASP.NET8 using DataTables.net โ€“ Part6 โ€“ Returning additional parameters in AJAX
Favicon
ASP.NET8 using DataTables.net โ€“ Part4 โ€“ Multilingual
Favicon
ASP.NET8 using DataTables.net โ€“ Part8 โ€“ Select rows
Favicon
ASP.NET8 using DataTables.net โ€“ Part3 โ€“ State saving
Favicon
ASP.NET8 using DataTables.net โ€“ Part7 โ€“ Buttons regular
Favicon
ASP.NET8 using DataTables.net โ€“ Part5 โ€“ Passing additional parameters in AJAX
Favicon
ASP.NET8 using DataTables.net โ€“ Part9 โ€“ Advanced Filters
Favicon
ASP.NET8 using DataTables.net โ€“ Part2 โ€“ Action buttons
Favicon
ASP.NET 8 โ€“ Multilingual Application with single Resx file โ€“ Part 3 โ€“ Forms Validation Strings

Featured ones: