Why Use This
This skill provides specialized capabilities for mitkox's codebase.
Use Cases
- Developing new features in the mitkox repository
- Refactoring existing code to follow mitkox standards
- Understanding and working with mitkox's codebase structure
Install Guide
2 steps - 1
- 2
Install inside Ananke
Click Install Skill, paste the link below, then press Install.
https://github.com/mitkox/ai-coding-factory/tree/master/.opencode/skill/net-docker
Skill Snapshot
Auto scan of skill assets. Informational only.
Valid SKILL.md
Checks against SKILL.md specification
Source & Community
Updated At Jan 10, 2026, 10:29 AM
Skill Stats
SKILL.md 174 Lines
Total Files 1
Total Size 0 B
License MIT
---
name: net-docker
description: Create Docker configuration for ASP.NET Core applications
license: MIT
compatibility: opencode
metadata:
audience: .net-developers
containers: docker
orchestration: docker-compose
---
## What I Do
I create Docker configuration for .NET apps:
- Multi-stage Dockerfile
- docker-compose for local development
- Production-ready configuration
- Health checks
- Volume mounts
- Environment variables
## When to Use Me
Use this skill when:
- Containerizing .NET application
- Setting up local development environment
- Preparing for deployment
- Creating container orchestration
## Docker Files
### Multi-stage Dockerfile
```dockerfile
# Build stage
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
WORKDIR /src
COPY ["src/ProjectName.Api/ProjectName.Api.csproj", "ProjectName.Api/"]
COPY ["src/ProjectName.Application/ProjectName.Application.csproj", "ProjectName.Application/"]
COPY ["src/ProjectName.Domain/ProjectName.Domain.csproj", "ProjectName.Domain/"]
COPY ["src/ProjectName.Infrastructure/ProjectName.Infrastructure.csproj", "ProjectName.Infrastructure/"]
RUN dotnet restore "ProjectName.Api/ProjectName.Api.csproj"
COPY . .
WORKDIR "/src/ProjectName.Api"
RUN dotnet build "ProjectName.Api.csproj" -c Release -o /app/build
# Publish stage
FROM build AS publish
RUN dotnet publish "ProjectName.Api.csproj" -c Release -o /app/publish /p:UseAppHost=false
# Runtime stage
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS final
WORKDIR /app
EXPOSE 80
EXPOSE 443
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "ProjectName.Api.dll"]
HEALTHCHECK --interval=30s --timeout=3s \
CMD curl -f http://localhost/health || exit 1
```
### Docker Compose
```yaml
version: '3.8'
services:
api:
build:
context: .
dockerfile: Dockerfile
ports:
- "5000:80"
- "5001:443"
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ConnectionStrings__DefaultConnection=Host=db;Database=appdb;Username=app;Password=app
- JwtSettings__Secret=your-secret-key
depends_on:
db:
condition: service_healthy
volumes:
- ./src/ProjectName.Api/appsettings.Development.json:/app/appsettings.Development.json
networks:
- app-network
db:
image: postgres:15-alpine
environment:
- POSTGRES_DB=appdb
- POSTGRES_USER=app
- POSTGRES_PASSWORD=app
ports:
- "5432:5432"
volumes:
- postgres-data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U app"]
interval: 10s
timeout: 5s
retries: 5
networks:
- app-network
redis:
image: redis:7-alpine
ports:
- "6379:6379"
volumes:
- redis-data:/data
networks:
- app-network
volumes:
postgres-data:
redis-data:
networks:
app-network:
driver: bridge
```
### Dockerignore
```
**/bin/
**/obj/
**/out/
**/.vs/
**/TestResults/
**/*.user
**/*.suo
**/*.cache
**/*.log
**/.vscode/
**/*.md
.git/
.gitignore
docker-compose*.yml
Dockerfile*
```
## Best Practices
1. Use multi-stage builds for smaller images
2. Use specific version tags (not `latest`)
3. Don't run as root (create non-root user)
4. Implement health checks
5. Use environment variables for configuration
6. Use volumes for persistence
7. Use networks for service communication
8. Optimize layer caching
## Production Considerations
1. Use Alpine images for smaller size
2. Scan images for vulnerabilities
3. Sign images for security
4. Use secrets management (not env vars in prod)
5. Implement resource limits
6. Use orchestration (Kubernetes)
7. Configure logging driver
8. Set up monitoring
## Example Usage
```
Create Docker configuration with:
- Multi-stage Dockerfile
- docker-compose for local dev
- PostgreSQL database
- Redis cache
- Health checks
- Volume mounts
```
I will generate complete Docker configuration.