Skip to content

Bits of .NET

Daily micro-tips for C#, SQL, performance, and scalable backend engineering.

  • Asp.Net Core
  • C#
  • SQL
  • JavaScript
  • CSS
  • About
  • ErcanOPAK.com
  • No Access
  • Privacy Policy
Docker

Docker: Never Write Logs to Files Inside Containers

- 07.06.26 - ErcanOPAK

📝 Log to stdout/stderr, Not Files

Log files inside container fill disk. Container restarts lose logs. Docker captures stdout/stderr. Use docker logs.

✅ Good vs Bad

// ❌ BAD: Writing to file
File.WriteAllText("/app/logs/app.log", message);

// ✅ GOOD: Console output
Console.WriteLine(message);

// ❌ BAD: Log4Net to file
// ✅ GOOD: Serilog to Console

// Docker command to see logs
docker logs container_name
docker logs -f container_name  # follow
docker logs --tail 100 container_name
docker logs --since 2024-01-01 container_name

🎯 JSON Logging

// Structured logging (JSON)
Console.WriteLine(JsonSerializer.Serialize(new {
    level = "Information",
    message = "User logged in",
    userId = 123,
    timestamp = DateTime.UtcNow
}));

// Docker parses JSON logs automatically
docker logs --details container_name

// Log drivers
docker run --log-driver json-file --log-opt max-size=10m --log-opt max-file=3
docker run --log-driver fluentd --log-opt fluentd-address=localhost:24224

💡 Log Management

  • Set log rotation: –log-opt max-size=10m –log-opt max-file=3
  • Use Fluentd, Logstash, or Loki for aggregation
  • ELK stack (Elasticsearch, Logstash, Kibana) for centralized logging
  • Never store logs inside container (they disappear on restart)

“Container crashed. Log file inside container lost. Switched to stdout. Now docker logs shows everything. Even after restart. Never write logs to files in containers.”

— DevOps Engineer

Related posts:

Docker — Containers Slow Because of OverlayFS

Docker: Stop Guessing if Your Container is Truly 'Healthy'

Docker: Run Containers as Non-Root User for Better Security

Post Views: 2

Post navigation

Kubernetes: Always Set CPU and Memory Requests and Limits
AI Prompt: Write Professional Emails from Bullet Points

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

June 2026
M T W T F S S
1234567
891011121314
15161718192021
22232425262728
2930  
« May    

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (953)
  • How to add default value for Entity Framework migrations for DateTime and Bool (882)
  • Get the First and Last Word from a String or Sentence in SQL (838)
  • How to select distinct rows in a datatable in C# (808)
  • How to make theater mode the default for Youtube (804)
  • Add Constraint to SQL Table to ensure email contains @ (580)
  • How to enable, disable and check if Service Broker is enabled on a database in SQL Server (579)
  • Average of all values in a column that are not zero in SQL (538)
  • How to use Map Mode for Vertical Scroll Mode in Visual Studio (505)
  • Find numbers with more than two decimal places in SQL (454)

Recent Posts

  • C#: Use String Interpolation Instead of Concatenation
  • C#: Use Tuples to Return Multiple Values from Methods
  • SQL: Use ISNULL and NULLIF for Smart NULL Handling
  • .NET Core: Use Data Annotations for Model Validation
  • Git: Use Git Clean to Remove Untracked Files
  • Ajax: Add Custom Headers to Fetch Requests
  • JavaScript: Use console.table to Display Arrays as Tables
  • HTML: Use Spellcheck Attribute to Enable Browser Spell Check
  • CSS: Use user-select to Prevent Text Selection
  • Windows 11: Use Snipping Tool for Instant Screenshots

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (953)
  • How to add default value for Entity Framework migrations for DateTime and Bool (882)
  • Get the First and Last Word from a String or Sentence in SQL (838)
  • How to select distinct rows in a datatable in C# (808)
  • How to make theater mode the default for Youtube (804)

Recent Posts

  • C#: Use String Interpolation Instead of Concatenation
  • C#: Use Tuples to Return Multiple Values from Methods
  • SQL: Use ISNULL and NULLIF for Smart NULL Handling
  • .NET Core: Use Data Annotations for Model Validation
  • Git: Use Git Clean to Remove Untracked Files

Social

  • ErcanOPAK.com
  • GoodReads
  • LetterBoxD
  • Linkedin
  • The Blog
  • Twitter
© 2026 Bits of .NET | Built with Xblog Plus free WordPress theme by wpthemespace.com