@xdev-asia/xdev-knowledge-mcp 1.0.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +137 -0
- package/content/blog/ai/ai-trong-y-te-healthcare.md +1364 -0
- package/content/blog/ai/gemma-4-mo-hinh-ai-mo-manh-nhat-google-agentic-edge.md +401 -0
- package/content/blog/ai/ollama-mlx-apple-silicon-chay-ai-local-nhanh-hon-3x.md +406 -0
- package/content/blog/database/ma-hoa-du-lieu-healthcare.md +518 -0
- package/content/blog/devops/cai-dat-harbor-tren-ubuntu-24-04.md +168 -0
- package/content/blog/devops/cai-dat-kvm-tren-ubuntu-24-04.md +159 -0
- package/content/blog/devops/cai-dat-kvm-tren-ubuntu-quan-ly-vm-qua-cockpit-web-ui.md +915 -0
- package/content/blog/devops/circuit-breaker-pattern-trong-spring-boot-huong-dan-chi-tiet-tu-a-z.md +1259 -0
- package/content/blog/devops/huong-dan-toan-dien-ve-backup-va-restore-postgresql.md +446 -0
- package/content/blog/devops/huong-dan-upgrade-postgresql-17-6-len-18-1-chuan-production.md +482 -0
- package/content/blog/devops/xay-dung-postgresql-high-availability-cluster-voi-ansible.md +105 -0
- package/content/blog/linux/cai-dat-openvpn-tren-ubuntu-2404.md +43 -0
- package/content/blog/programming/claude-code-source-code-bi-mat-buddy-ultraplan.md +970 -0
- package/content/blog/programming/xay-dung-ai-agent-platform-voi-xclaw-huong-dan-thuc-chien.md +1032 -0
- package/content/blog/security/thiet-ke-kien-truc-phan-quyen-du-lieu-theo-cap-hanh-chinh.md +399 -0
- package/content/metadata/authors/duy-tran.md +23 -0
- package/content/metadata/categories/architecture.md +20 -0
- package/content/metadata/categories/backend.md +23 -0
- package/content/metadata/categories/database-course.md +23 -0
- package/content/metadata/categories/database.md +23 -0
- package/content/metadata/categories/devops.md +23 -0
- package/content/metadata/categories/kubernetes.md +23 -0
- package/content/metadata/categories/linux.md +23 -0
- package/content/metadata/categories/security.md +23 -0
- package/content/metadata/categories/spring-boot.md +23 -0
- package/content/metadata/categories/web-server.md +23 -0
- package/content/metadata/tags/adobe.md +13 -0
- package/content/metadata/tags/aes-256.md +13 -0
- package/content/metadata/tags/ai-agents.md +13 -0
- package/content/metadata/tags/ai-coding.md +13 -0
- package/content/metadata/tags/ai.md +13 -0
- package/content/metadata/tags/aks.md +13 -0
- package/content/metadata/tags/ansible.md +13 -0
- package/content/metadata/tags/anthropic.md +13 -0
- package/content/metadata/tags/apigateway.md +13 -0
- package/content/metadata/tags/argocd.md +13 -0
- package/content/metadata/tags/audit-logging.md +13 -0
- package/content/metadata/tags/authorization.md +13 -0
- package/content/metadata/tags/automated-failover.md +13 -0
- package/content/metadata/tags/backend.md +13 -0
- package/content/metadata/tags/backup-recovery.md +13 -0
- package/content/metadata/tags/backup.md +13 -0
- package/content/metadata/tags/best-practices.md +13 -0
- package/content/metadata/tags/bun.md +13 -0
- package/content/metadata/tags/caching.md +13 -0
- package/content/metadata/tags/canarydeployment.md +13 -0
- package/content/metadata/tags/careerdevelopment.md +13 -0
- package/content/metadata/tags/cdn.md +13 -0
- package/content/metadata/tags/chinh-sua-anh.md +13 -0
- package/content/metadata/tags/chrome-extension.md +13 -0
- package/content/metadata/tags/cicd.md +13 -0
- package/content/metadata/tags/circuit-breaker.md +13 -0
- package/content/metadata/tags/cka.md +13 -0
- package/content/metadata/tags/ckad.md +13 -0
- package/content/metadata/tags/claude-code.md +13 -0
- package/content/metadata/tags/cloud-native.md +13 -0
- package/content/metadata/tags/cloudcomputing.md +13 -0
- package/content/metadata/tags/cluster-management.md +13 -0
- package/content/metadata/tags/cockpit.md +13 -0
- package/content/metadata/tags/container-orchestration.md +13 -0
- package/content/metadata/tags/container.md +13 -0
- package/content/metadata/tags/database-administration.md +13 -0
- package/content/metadata/tags/database-clustering.md +13 -0
- package/content/metadata/tags/database-migration.md +13 -0
- package/content/metadata/tags/database.md +13 -0
- package/content/metadata/tags/datamanagement.md +13 -0
- package/content/metadata/tags/design-pattern.md +13 -0
- package/content/metadata/tags/developer-tools.md +13 -0
- package/content/metadata/tags/devops.md +13 -0
- package/content/metadata/tags/disaster-recovery.md +13 -0
- package/content/metadata/tags/distributed-systems.md +13 -0
- package/content/metadata/tags/docker-registry.md +13 -0
- package/content/metadata/tags/docker.md +13 -0
- package/content/metadata/tags/easy-rsa.md +13 -0
- package/content/metadata/tags/eks.md +13 -0
- package/content/metadata/tags/encryption.md +13 -0
- package/content/metadata/tags/enterprise-architecture.md +13 -0
- package/content/metadata/tags/enterprise.md +13 -0
- package/content/metadata/tags/etcd.md +13 -0
- package/content/metadata/tags/failover.md +13 -0
- package/content/metadata/tags/fault-tolerance.md +13 -0
- package/content/metadata/tags/generative-fill.md +13 -0
- package/content/metadata/tags/gitops.md +13 -0
- package/content/metadata/tags/gke.md +13 -0
- package/content/metadata/tags/grafana.md +13 -0
- package/content/metadata/tags/hands-on.md +13 -0
- package/content/metadata/tags/handson.md +13 -0
- package/content/metadata/tags/harbor.md +13 -0
- package/content/metadata/tags/healthcare.md +13 -0
- package/content/metadata/tags/helm.md +13 -0
- package/content/metadata/tags/high-availability.md +13 -0
- package/content/metadata/tags/highavailability.md +13 -0
- package/content/metadata/tags/hipaa.md +13 -0
- package/content/metadata/tags/homelab.md +13 -0
- package/content/metadata/tags/hono.md +13 -0
- package/content/metadata/tags/http2.md +13 -0
- package/content/metadata/tags/https.md +13 -0
- package/content/metadata/tags/hypervisor.md +13 -0
- package/content/metadata/tags/iam.md +10 -0
- package/content/metadata/tags/infrastructure-as-code.md +13 -0
- package/content/metadata/tags/infrastructure.md +13 -0
- package/content/metadata/tags/ingress.md +13 -0
- package/content/metadata/tags/istio.md +13 -0
- package/content/metadata/tags/java.md +13 -0
- package/content/metadata/tags/javascript.md +13 -0
- package/content/metadata/tags/k8s.md +13 -0
- package/content/metadata/tags/keycloak.md +10 -0
- package/content/metadata/tags/kimchi.md +13 -0
- package/content/metadata/tags/kubernetes.md +13 -0
- package/content/metadata/tags/kvm.md +13 -0
- package/content/metadata/tags/ldap.md +10 -0
- package/content/metadata/tags/libvirt.md +13 -0
- package/content/metadata/tags/linux.md +13 -0
- package/content/metadata/tags/loadbalancer.md +13 -0
- package/content/metadata/tags/mcp.md +13 -0
- package/content/metadata/tags/mfa.md +10 -0
- package/content/metadata/tags/microservices.md +13 -0
- package/content/metadata/tags/mien-phi.md +13 -0
- package/content/metadata/tags/mongodb.md +13 -0
- package/content/metadata/tags/monitoring.md +13 -0
- package/content/metadata/tags/monorepo.md +13 -0
- package/content/metadata/tags/multi-tenant.md +13 -0
- package/content/metadata/tags/networking.md +13 -0
- package/content/metadata/tags/nginx.md +13 -0
- package/content/metadata/tags/oauth2.md +10 -0
- package/content/metadata/tags/oidc.md +10 -0
- package/content/metadata/tags/open-source.md +13 -0
- package/content/metadata/tags/openvpn.md +13 -0
- package/content/metadata/tags/passkeys.md +10 -0
- package/content/metadata/tags/patroni.md +13 -0
- package/content/metadata/tags/performance.md +13 -0
- package/content/metadata/tags/pg-upgrade.md +13 -0
- package/content/metadata/tags/phi.md +13 -0
- package/content/metadata/tags/photoshop-web.md +13 -0
- package/content/metadata/tags/photoshop.md +13 -0
- package/content/metadata/tags/pii.md +13 -0
- package/content/metadata/tags/postgresql-18.md +13 -0
- package/content/metadata/tags/postgresql-high-availability-voi-patroni-etcd-course.md +13 -0
- package/content/metadata/tags/postgresql.md +13 -0
- package/content/metadata/tags/production-deployment.md +13 -0
- package/content/metadata/tags/production.md +13 -0
- package/content/metadata/tags/prometheus.md +13 -0
- package/content/metadata/tags/qemu.md +13 -0
- package/content/metadata/tags/rag.md +13 -0
- package/content/metadata/tags/ratelimiting.md +13 -0
- package/content/metadata/tags/rbac.md +13 -0
- package/content/metadata/tags/react.md +13 -0
- package/content/metadata/tags/realworld.md +13 -0
- package/content/metadata/tags/replication.md +13 -0
- package/content/metadata/tags/resilience4j.md +13 -0
- package/content/metadata/tags/rest-api.md +13 -0
- package/content/metadata/tags/reverseproxy.md +13 -0
- package/content/metadata/tags/rls.md +13 -0
- package/content/metadata/tags/roeadwarrior.md +13 -0
- package/content/metadata/tags/runtime.md +13 -0
- package/content/metadata/tags/saml.md +10 -0
- package/content/metadata/tags/security.md +13 -0
- package/content/metadata/tags/self-hosted.md +13 -0
- package/content/metadata/tags/server.md +13 -0
- package/content/metadata/tags/spring-boot.md +13 -0
- package/content/metadata/tags/sre.md +13 -0
- package/content/metadata/tags/ssl.md +13 -0
- package/content/metadata/tags/sso.md +10 -0
- package/content/metadata/tags/statefulset.md +13 -0
- package/content/metadata/tags/storage.md +13 -0
- package/content/metadata/tags/streaming-replication.md +13 -0
- package/content/metadata/tags/system-administration.md +13 -0
- package/content/metadata/tags/system-design.md +13 -0
- package/content/metadata/tags/systemadmin.md +13 -0
- package/content/metadata/tags/systemadministration.md +13 -0
- package/content/metadata/tags/thiet-ke-do-hoa.md +13 -0
- package/content/metadata/tags/tutorial.md +13 -0
- package/content/metadata/tags/typescript.md +13 -0
- package/content/metadata/tags/ubuntu-2404.md +13 -0
- package/content/metadata/tags/ubuntu.md +13 -0
- package/content/metadata/tags/virtual-machines.md +13 -0
- package/content/metadata/tags/virtualization.md +13 -0
- package/content/metadata/tags/vpn-server.md +13 -0
- package/content/metadata/tags/web-ui.md +13 -0
- package/content/metadata/tags/webserver.md +13 -0
- package/content/metadata/tags/workflow.md +13 -0
- package/content/pages/chinh-sach-quyen-rieng-tu.md +31 -0
- package/content/pages/dieu-khoan-su-dung.md +26 -0
- package/content/pages/gioi-thieu.md +23 -0
- package/content/pages/privacy-policy.md +100 -0
- package/content/pages/your-privacy-choices.md +53 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/02-bai-1-tong-quan-ai-ml-dl-va-llm.md +274 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/03-bai-2-toan-hoc-cho-ai.md +552 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/04-bai-3-neural-networks-co-ban.md +557 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/05-bai-4-deep-learning-overview.md +471 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/06-bai-5-attention-mechanism.md +262 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/07-bai-6-kien-truc-transformer.md +360 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/08-bai-7-bert-va-encoder-only-models.md +328 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/09-bai-8-gpt-va-decoder-only-models.md +358 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/10-bai-9-tokenization.md +506 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/11-bai-10-pre-training-llms.md +283 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/12-bai-11-supervised-fine-tuning.md +469 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/13-bai-12-peft-lora-qlora.md +420 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/14-bai-13-rlhf-va-alignment.md +419 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/15-bai-14-prompt-engineering.md +334 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/16-bai-15-advanced-prompting.md +352 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/17-bai-16-rag-retrieval-augmented-generation.md +428 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/18-bai-17-vector-databases.md +471 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/05-phan-5-ai-applications/lessons/19-bai-18-ai-agents.md +455 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/05-phan-5-ai-applications/lessons/20-bai-19-llm-apis.md +441 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-nang-cao/lessons/21-bai-20-deploying-llms-va-evaluation.md +456 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-nang-cao/lessons/22-bai-21-ollama-apple-silicon.md +1254 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/index.md +376 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/01-phan-1-kien-truc-ai-system/lessons/01-bai-1-tong-quan-fashion-ai-platform-tach-lop-ai.md +292 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/01-phan-1-kien-truc-ai-system/lessons/02-bai-2-kien-truc-ai-system-microservices-model-pipeline.md +403 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/01-phan-1-kien-truc-ai-system/lessons/03-bai-3-ai-tech-stack-diffusion-vision-llm-mlops.md +427 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/04-bai-4-text-to-design-fine-tune-stable-diffusion.md +435 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/05-bai-5-image-reference-analysis-clip-style-transfer.md +349 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/06-bai-6-multi-modal-generation-text-image.md +260 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/07-bai-7-prompt-engineering-cho-fashion.md +269 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/08-bai-8-print-ready-ai-layout-rules-safe-margins.md +322 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/09-bai-9-auto-scaling-design-resize-theo-size-form.md +242 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/10-bai-10-ai-editing-assistant-natural-language.md +319 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/11-bai-11-ai-typography-generate-text-font-placement.md +285 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/12-bai-12-style-analysis-engine-phan-tich-gu-tham-my.md +257 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/13-bai-13-behavioral-learning-hoc-hanh-vi-preference.md +303 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/14-bai-14-ai-recommendation-system-goi-y-design.md +258 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/15-bai-15-ai-size-recommendation-body-measurement.md +264 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/16-bai-16-body-estimation-du-doan-body-shape.md +317 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/17-bai-17-3d-avatar-generation-tao-avatar.md +339 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/18-bai-18-garment-rendering-render-ao-len-avatar.md +325 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/19-bai-19-real-time-virtual-try-on-360-rotation.md +371 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/20-bai-20-print-file-optimization-rgb-cmyk-dpi.md +364 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/21-bai-21-ai-auto-tagging-gan-tag-phan-loai.md +363 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/22-bai-22-ai-product-generation-title-description-mockup.md +327 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/23-bai-23-trending-detection-xu-huong-content-moderation.md +402 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/24-bai-24-production-deployment-mlops-pipeline-scaling.md +574 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/index.md +482 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/01-phan-1-nen-tang-ai-y-te-medical-data/lessons/02-bai-1-ai-y-te-tong-quan.md +388 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/01-phan-1-nen-tang-ai-y-te-medical-data/lessons/03-bai-2-du-lieu-y-te-dicom-fhir.md +576 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/01-phan-1-nen-tang-ai-y-te-medical-data/lessons/04-bai-3-medical-image-processing.md +534 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/02-phan-2-medical-imaging-ai-computer-vision-cho-y-te/lessons/05-bai-4-cnn-medical-classification.md +614 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/02-phan-2-medical-imaging-ai-computer-vision-cho-y-te/lessons/06-bai-5-unet-segmentation.md +525 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/02-phan-2-medical-imaging-ai-computer-vision-cho-y-te/lessons/07-bai-6-detection-pathology.md +627 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/08-bai-7-clinical-nlp.md +223 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/09-bai-8-medical-qa-chatbot.md +318 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/10-bai-9-drug-discovery-gnn.md +300 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/11-bai-10-genomics-protein.md +302 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/12-bai-11-federated-learning-y-te.md +291 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/13-bai-12-xai-y-te.md +276 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/14-bai-13-fda-regulatory.md +267 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/15-bai-14-deploy-medical-ai.md +332 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/16-bai-15-capstone-medical-ai.md +435 -0
- package/content/series/ai/ai-trong-y-te-healthcare/index.md +208 -0
- package/content/series/ai/build-ai-agents/chapters/01-phan-1-nen-tang-agent/lessons/02-bai-1-agent-la-gi.md +365 -0
- package/content/series/ai/build-ai-agents/chapters/01-phan-1-nen-tang-agent/lessons/03-bai-2-llm-apis-masterclass.md +271 -0
- package/content/series/ai/build-ai-agents/chapters/01-phan-1-nen-tang-agent/lessons/04-bai-3-prompt-engineering-cho-agent.md +164 -0
- package/content/series/ai/build-ai-agents/chapters/02-phan-2-function-calling-tool-use/lessons/05-bai-4-function-calling.md +161 -0
- package/content/series/ai/build-ai-agents/chapters/02-phan-2-function-calling-tool-use/lessons/06-bai-5-xay-dung-custom-tools.md +124 -0
- package/content/series/ai/build-ai-agents/chapters/02-phan-2-function-calling-tool-use/lessons/07-bai-6-the-agent-loop.md +117 -0
- package/content/series/ai/build-ai-agents/chapters/03-phan-3-rag-memory/lessons/08-bai-7-rag-cho-agent.md +82 -0
- package/content/series/ai/build-ai-agents/chapters/03-phan-3-rag-memory/lessons/09-bai-8-agent-memory.md +76 -0
- package/content/series/ai/build-ai-agents/chapters/04-phan-4-agentic-frameworks/lessons/10-bai-9-langchain-langgraph.md +73 -0
- package/content/series/ai/build-ai-agents/chapters/04-phan-4-agentic-frameworks/lessons/11-bai-10-crewai.md +73 -0
- package/content/series/ai/build-ai-agents/chapters/04-phan-4-agentic-frameworks/lessons/12-bai-11-advanced-patterns.md +73 -0
- package/content/series/ai/build-ai-agents/chapters/05-phan-5-mcp-a2a-multi-agent/lessons/13-bai-12-mcp.md +68 -0
- package/content/series/ai/build-ai-agents/chapters/05-phan-5-mcp-a2a-multi-agent/lessons/14-bai-13-a2a-protocol.md +65 -0
- package/content/series/ai/build-ai-agents/chapters/05-phan-5-mcp-a2a-multi-agent/lessons/15-bai-14-multi-agent-orchestration.md +76 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/16-bai-15-guardrails-safety.md +74 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/17-bai-16-observability-evaluation.md +74 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/18-bai-17-deploy-agent-production.md +85 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/19-bai-18-capstone-project.md +129 -0
- package/content/series/ai/build-ai-agents/index.md +372 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/01-phan-1-nen-tang-cv/lessons/02-bai-1-computer-vision-la-gi.md +450 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/01-phan-1-nen-tang-cv/lessons/03-bai-2-cnn-deep-dive.md +514 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/01-phan-1-nen-tang-cv/lessons/04-bai-3-transfer-learning.md +427 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/02-phan-2-object-detection/lessons/05-bai-4-yolo-object-detection.md +374 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/02-phan-2-object-detection/lessons/06-bai-5-train-yolo-custom.md +440 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/02-phan-2-object-detection/lessons/07-bai-6-realtime-detection.md +359 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/08-bai-7-image-segmentation.md +310 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/09-bai-8-sam-segment-anything.md +373 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/10-bai-9-image-generation.md +332 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/11-bai-10-vision-transformer-clip.md +413 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/04-phan-4-ung-dung-thuc-te/lessons/12-bai-11-ocr-document-understanding.md +353 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/04-phan-4-ung-dung-thuc-te/lessons/13-bai-12-multimodal-ai.md +342 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/05-phan-5-deployment-capstone/lessons/14-bai-13-edge-deployment.md +628 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/05-phan-5-deployment-capstone/lessons/15-bai-14-capstone.md +653 -0
- package/content/series/ai/computer-vision-deep-learning/index.md +287 -0
- package/content/series/ai/fine-tuning-llm/chapters/01-phan-1-tong-quan-chien-luoc/lessons/02-bai-1-fine-tuning-la-gi.md +247 -0
- package/content/series/ai/fine-tuning-llm/chapters/01-phan-1-tong-quan-chien-luoc/lessons/03-bai-2-fine-tuning-vs-rag.md +224 -0
- package/content/series/ai/fine-tuning-llm/chapters/01-phan-1-tong-quan-chien-luoc/lessons/04-bai-3-chi-phi-fine-tuning.md +129 -0
- package/content/series/ai/fine-tuning-llm/chapters/02-phan-2-chuan-bi-du-lieu/lessons/05-bai-4-thu-thap-thiet-ke-dataset.md +102 -0
- package/content/series/ai/fine-tuning-llm/chapters/02-phan-2-chuan-bi-du-lieu/lessons/06-bai-5-data-cleaning-augmentation.md +96 -0
- package/content/series/ai/fine-tuning-llm/chapters/03-phan-3-fine-tuning-gemini/lessons/07-bai-6-vertex-ai-setup.md +93 -0
- package/content/series/ai/fine-tuning-llm/chapters/03-phan-3-fine-tuning-gemini/lessons/08-bai-7-fine-tune-gemini-flash.md +107 -0
- package/content/series/ai/fine-tuning-llm/chapters/03-phan-3-fine-tuning-gemini/lessons/09-bai-8-fine-tune-gemini-production.md +83 -0
- package/content/series/ai/fine-tuning-llm/chapters/04-phan-4-fine-tuning-openai/lessons/10-bai-9-fine-tune-openai.md +79 -0
- package/content/series/ai/fine-tuning-llm/chapters/04-phan-4-fine-tuning-openai/lessons/11-bai-10-lora-qlora.md +96 -0
- package/content/series/ai/fine-tuning-llm/chapters/05-phan-5-danh-gia-model/lessons/12-bai-11-metrics-danh-gia-llm.md +100 -0
- package/content/series/ai/fine-tuning-llm/chapters/05-phan-5-danh-gia-model/lessons/13-bai-12-llm-as-a-judge.md +93 -0
- package/content/series/ai/fine-tuning-llm/chapters/05-phan-5-danh-gia-model/lessons/14-bai-13-evaluation-pipeline.md +101 -0
- package/content/series/ai/fine-tuning-llm/chapters/06-phan-6-production/lessons/15-bai-14-deployment.md +88 -0
- package/content/series/ai/fine-tuning-llm/chapters/06-phan-6-production/lessons/16-bai-15-common-pitfalls.md +81 -0
- package/content/series/ai/fine-tuning-llm/chapters/06-phan-6-production/lessons/17-bai-16-capstone.md +118 -0
- package/content/series/ai/fine-tuning-llm/index.md +363 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/01-phan-1-foundation-gemma-4-local-stack/lessons/01-bai-1-thiet-ke-local-ai-architecture-cho-team-dev.md +343 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/01-phan-1-foundation-gemma-4-local-stack/lessons/02-bai-2-setup-gemma-4-voi-ollama-va-open-webui-tren-mac.md +106 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/02-phan-2-integration-api-prompting/lessons/03-bai-3-xay-api-gateway-cho-gemma-4-va-policy-tang-ung-dung.md +108 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/02-phan-2-integration-api-prompting/lessons/04-bai-4-prompt-contracts-json-schema-va-regression-test-cho-llm.md +102 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/03-phan-3-rag-engineering-du-lieu-noi-bo/lessons/05-bai-5-ingestion-chunking-va-vector-indexing-cho-tieng-viet.md +101 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/03-phan-3-rag-engineering-du-lieu-noi-bo/lessons/06-bai-6-hybrid-retrieval-bm25-vector-reranker.md +84 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/04-phan-4-reliability-cost-production-hardening/lessons/07-bai-7-eval-framework-observability-va-slo-cho-genai.md +82 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/04-phan-4-reliability-cost-production-hardening/lessons/08-bai-8-hardening-va-rollout-local-ai-stack-cho-doanh-nghiep.md +90 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/index.md +64 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/01-phan-1-nen-tang-generative-ai/lessons/02-bai-1-generative-ai-la-gi.md +233 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/01-phan-1-nen-tang-generative-ai/lessons/03-bai-2-gan.md +299 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/01-phan-1-nen-tang-generative-ai/lessons/04-bai-3-vae.md +280 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/02-phan-2-diffusion-models/lessons/05-bai-4-diffusion-models.md +229 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/02-phan-2-diffusion-models/lessons/06-bai-5-stable-diffusion.md +236 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/02-phan-2-diffusion-models/lessons/07-bai-6-prompt-engineering.md +227 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/03-phan-3-image-generation-nang-cao/lessons/08-bai-7-controlnet.md +220 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/03-phan-3-image-generation-nang-cao/lessons/09-bai-8-inpainting.md +242 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/03-phan-3-image-generation-nang-cao/lessons/10-bai-9-lora-custom-training.md +254 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/04-phan-4-dall-e-midjourney-apis/lessons/11-bai-10-dall-e-3-api.md +251 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/04-phan-4-dall-e-midjourney-apis/lessons/12-bai-11-midjourney-flux.md +220 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/05-phan-5-video-generation/lessons/13-bai-12-video-generation.md +242 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/05-phan-5-video-generation/lessons/14-bai-13-audio-music.md +232 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/05-phan-5-video-generation/lessons/15-bai-14-3d-generation.md +245 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/16-bai-15-comfyui.md +260 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/17-bai-16-api-server.md +349 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/18-bai-17-ai-safety.md +280 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/19-bai-18-capstone.md +379 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/index.md +339 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/01-phan-1-nen-tang-recommendation-systems/lessons/02-bai-1-recsys-tong-quan.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/01-phan-1-nen-tang-recommendation-systems/lessons/03-bai-2-collaborative-filtering.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/01-phan-1-nen-tang-recommendation-systems/lessons/04-bai-3-matrix-factorization.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/05-bai-4-content-based-features.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/06-bai-5-neural-cf-embedding.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/07-bai-6-two-tower-retrieval.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/08-bai-7-sequence-models-recsys.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/03-phan-3-advanced-recsys-knowledge-graph-multi-task-gnn/lessons/09-bai-8-gnn-recommendation.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/03-phan-3-advanced-recsys-knowledge-graph-multi-task-gnn/lessons/10-bai-9-knowledge-graph-recsys.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/03-phan-3-advanced-recsys-knowledge-graph-multi-task-gnn/lessons/11-bai-10-multi-task-ranking.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/12-bai-11-llm-recommendations.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/13-bai-12-production-recsys-architecture.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/14-bai-13-ab-testing-evaluation.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/15-bai-14-capstone-recsys.md +53 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/index.md +199 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/01-bai-1-ml-la-gi.md +206 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/02-bai-2-setup-moi-truong-ml.md +242 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/03-bai-3-python-pandas-crash-course.md +243 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/04-bai-4-model-dau-tien-baseline.md +186 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/05-bai-5-mini-project-1-du-doan-gia-nha.md +165 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/06-bai-6-linear-regression-gradient-descent.md +113 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/07-bai-7-logistic-regression.md +100 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/08-bai-8-metrics-quan-trong.md +96 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/09-bai-9-overfitting-underfitting.md +88 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/10-bai-10-mini-project-2-churn.md +100 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/11-bai-11-missing-categorical-feature-engineering.md +89 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/12-bai-12-pipelines-columntransformer.md +91 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/13-bai-13-cross-validation-tuning.md +86 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/14-bai-14-data-leakage-error-analysis.md +85 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/15-bai-15-challenge-house-prices.md +84 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/16-bai-16-decision-tree-random-forest-xgboost.md +82 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/17-bai-17-clustering.md +81 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/18-bai-18-pca-tsne-umap.md +76 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/19-bai-19-anomaly-detection.md +76 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/20-bai-20-time-series-forecasting.md +84 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/index.md +28 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/21-bai-21-explainability-fairness.md +88 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/22-bai-22-model-serving-fastapi-docker.md +95 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/23-bai-23-monitoring-drift-retraining.md +88 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/24-bai-24-capstone-ml-end-to-end.md +74 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/index.md +364 -0
- package/content/series/ai/mlops-llmops/chapters/01-phan-1-mlops-foundations/lessons/02-bai-1-mlops-la-gi.md +342 -0
- package/content/series/ai/mlops-llmops/chapters/01-phan-1-mlops-foundations/lessons/03-bai-2-experiment-tracking.md +522 -0
- package/content/series/ai/mlops-llmops/chapters/01-phan-1-mlops-foundations/lessons/04-bai-3-data-versioning.md +493 -0
- package/content/series/ai/mlops-llmops/chapters/02-phan-2-ml-infrastructure/lessons/05-bai-4-model-registry.md +459 -0
- package/content/series/ai/mlops-llmops/chapters/02-phan-2-ml-infrastructure/lessons/06-bai-5-cicd-cho-ml.md +531 -0
- package/content/series/ai/mlops-llmops/chapters/02-phan-2-ml-infrastructure/lessons/07-bai-6-infrastructure.md +548 -0
- package/content/series/ai/mlops-llmops/chapters/03-phan-3-llmops/lessons/08-bai-7-llmops-vs-mlops.md +413 -0
- package/content/series/ai/mlops-llmops/chapters/03-phan-3-llmops/lessons/09-bai-8-prompt-management.md +514 -0
- package/content/series/ai/mlops-llmops/chapters/03-phan-3-llmops/lessons/10-bai-9-llm-observability.md +487 -0
- package/content/series/ai/mlops-llmops/chapters/04-phan-4-production-governance/lessons/11-bai-10-cost-optimization.md +511 -0
- package/content/series/ai/mlops-llmops/chapters/04-phan-4-production-governance/lessons/12-bai-11-guardrails-compliance.md +614 -0
- package/content/series/ai/mlops-llmops/chapters/04-phan-4-production-governance/lessons/13-bai-12-capstone.md +712 -0
- package/content/series/ai/mlops-llmops/index.md +276 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/01-phan-1-nen-tang-multimodal-learning/lessons/02-bai-1-multimodal-ai-la-gi.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/01-phan-1-nen-tang-multimodal-learning/lessons/03-bai-2-clip-contrastive-learning.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/01-phan-1-nen-tang-multimodal-learning/lessons/04-bai-3-vision-encoders-vit.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/05-bai-4-image-captioning.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/06-bai-5-vqa.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/07-bai-6-llava-vlm.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/08-bai-7-gpt4v-gemini.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/03-phan-3-document-ai-video-understanding/lessons/09-bai-8-document-ai-ocr.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/03-phan-3-document-ai-video-understanding/lessons/10-bai-9-video-understanding.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/03-phan-3-document-ai-video-understanding/lessons/11-bai-10-text-to-image.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/12-bai-11-multimodal-rag.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/13-bai-12-embodied-ai.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/14-bai-13-deploy-multimodal.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/15-bai-14-capstone-multimodal.md +53 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/index.md +199 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nlp/lessons/02-bai-1-nlp-la-gi.md +241 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nlp/lessons/03-bai-2-text-preprocessing.md +298 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nlp/lessons/04-bai-3-tokenization-deep-dive.md +235 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/02-phan-2-bieu-dien-ngon-ngu/lessons/05-bai-4-bow-tfidf-ngrams.md +170 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/02-phan-2-bieu-dien-ngon-ngu/lessons/06-bai-5-word-embeddings.md +247 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/02-phan-2-bieu-dien-ngon-ngu/lessons/07-bai-6-sentence-document-embeddings.md +189 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/03-phan-3-deep-learning-nlp/lessons/08-bai-7-rnn-lstm.md +182 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/03-phan-3-deep-learning-nlp/lessons/09-bai-8-attention-mechanism.md +168 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/03-phan-3-deep-learning-nlp/lessons/10-bai-9-transformer.md +181 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/04-phan-4-pretrained-language-models/lessons/11-bai-10-bert.md +170 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/04-phan-4-pretrained-language-models/lessons/12-bai-11-gpt-autoregressive.md +149 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/04-phan-4-pretrained-language-models/lessons/13-bai-12-hugging-face-ecosystem.md +203 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/14-bai-13-text-classification-sentiment.md +203 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/15-bai-14-ner.md +207 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/16-bai-15-question-answering.md +209 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/17-bai-16-summarization-translation.md +164 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/18-bai-17-nlp-tieng-viet.md +190 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/19-bai-18-nlp-pipeline-production.md +243 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/20-bai-19-llm-nlp-hien-dai.md +219 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/21-bai-20-capstone-project.md +270 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/index.md +401 -0
- package/content/series/ai/ollama-apple-silicon/chapters/01-phan-1-nen-tang-ollama-apple-silicon/lessons/01-bai-1-apple-silicon-ai-tai-sao-m-chip-la-vua-inference-local.md +216 -0
- package/content/series/ai/ollama-apple-silicon/chapters/01-phan-1-nen-tang-ollama-apple-silicon/lessons/02-bai-2-cai-dat-ollama-tu-zero-den-chay-llm-trong-5-phut.md +353 -0
- package/content/series/ai/ollama-apple-silicon/chapters/01-phan-1-nen-tang-ollama-apple-silicon/lessons/03-bai-3-chon-model-phu-hop-so-sanh-llm-cho-mac.md +267 -0
- package/content/series/ai/ollama-apple-silicon/chapters/02-phan-2-mlx-tang-toc-3x/lessons/04-bai-4-mlx-framework-apple-intelligence-duoi-nap-capo.md +267 -0
- package/content/series/ai/ollama-apple-silicon/chapters/02-phan-2-mlx-tang-toc-3x/lessons/05-bai-5-cai-dat-mlx-lm-va-chay-model-mlx-quantized.md +372 -0
- package/content/series/ai/ollama-apple-silicon/chapters/02-phan-2-mlx-tang-toc-3x/lessons/06-bai-6-ollama-mlx-backend-ket-hop-tot-nhat-cua-hai-the-gioi.md +314 -0
- package/content/series/ai/ollama-apple-silicon/chapters/03-phan-3-tich-hop-api-lap-trinh/lessons/07-bai-7-ollama-rest-api-openai-compatible-endpoint.md +395 -0
- package/content/series/ai/ollama-apple-silicon/chapters/03-phan-3-tich-hop-api-lap-trinh/lessons/08-bai-8-python-integration-xay-chatbot-local-voi-ollama.md +450 -0
- package/content/series/ai/ollama-apple-silicon/chapters/03-phan-3-tich-hop-api-lap-trinh/lessons/09-bai-9-vision-models-phan-tich-hinh-anh-khong-can-cloud.md +392 -0
- package/content/series/ai/ollama-apple-silicon/chapters/04-phan-4-toi-uu-quan-ly-production/lessons/10-bai-10-toi-uu-hieu-nang-ram-context-concurrency.md +497 -0
- package/content/series/ai/ollama-apple-silicon/chapters/04-phan-4-toi-uu-quan-ly-production/lessons/11-bai-11-modelfiles-custom-models-va-system-prompts.md +481 -0
- package/content/series/ai/ollama-apple-silicon/chapters/04-phan-4-toi-uu-quan-ly-production/lessons/12-bai-12-workflow-hoan-chinh-personal-ai-setup-2026.md +637 -0
- package/content/series/ai/ollama-apple-silicon/index.md +57 -0
- package/content/series/ai/ollama-apple-silicon/index.md.tmp +239 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/01-phan-1-nen-tang/lessons/02-bai-1-prompt-engineering-la-gi.md +362 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/01-phan-1-nen-tang/lessons/03-bai-2-system-prompts-persona.md +433 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/01-phan-1-nen-tang/lessons/04-bai-3-few-shot-zero-shot.md +424 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/02-phan-2-ky-thuat-nang-cao/lessons/05-bai-4-chain-of-thought.md +320 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/02-phan-2-ky-thuat-nang-cao/lessons/06-bai-5-tree-of-thoughts.md +294 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/02-phan-2-ky-thuat-nang-cao/lessons/07-bai-6-structured-output.md +355 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/03-phan-3-ung-dung-thuc-te/lessons/08-bai-7-prompt-cho-code.md +323 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/03-phan-3-ung-dung-thuc-te/lessons/09-bai-8-prompt-data-business.md +333 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/03-phan-3-ung-dung-thuc-te/lessons/10-bai-9-multimodal-prompting.md +327 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/04-phan-4-production/lessons/11-bai-10-prompt-testing.md +437 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/04-phan-4-production/lessons/12-bai-11-prompt-versioning.md +473 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/04-phan-4-production/lessons/13-bai-12-capstone.md +423 -0
- package/content/series/ai/prompt-engineering-masterclass/index.md +266 -0
- package/content/series/ai/rag-thuc-chien/chapters/01-phan-1-nen-tang-rag/lessons/02-bai-1-rag-la-gi.md +349 -0
- package/content/series/ai/rag-thuc-chien/chapters/01-phan-1-nen-tang-rag/lessons/03-bai-2-embedding-models.md +308 -0
- package/content/series/ai/rag-thuc-chien/chapters/01-phan-1-nen-tang-rag/lessons/04-bai-3-vector-databases.md +351 -0
- package/content/series/ai/rag-thuc-chien/chapters/02-phan-2-document-processing/lessons/05-bai-4-document-loading.md +302 -0
- package/content/series/ai/rag-thuc-chien/chapters/02-phan-2-document-processing/lessons/06-bai-5-chunking-strategies.md +320 -0
- package/content/series/ai/rag-thuc-chien/chapters/02-phan-2-document-processing/lessons/07-bai-6-metadata-hybrid-search.md +385 -0
- package/content/series/ai/rag-thuc-chien/chapters/03-phan-3-query-retrieval/lessons/08-bai-7-query-transformation.md +335 -0
- package/content/series/ai/rag-thuc-chien/chapters/03-phan-3-query-retrieval/lessons/09-bai-8-reranking-compression.md +319 -0
- package/content/series/ai/rag-thuc-chien/chapters/03-phan-3-query-retrieval/lessons/10-bai-9-graph-rag.md +351 -0
- package/content/series/ai/rag-thuc-chien/chapters/04-phan-4-advanced-rag/lessons/11-bai-10-multimodal-rag.md +359 -0
- package/content/series/ai/rag-thuc-chien/chapters/04-phan-4-advanced-rag/lessons/12-bai-11-agentic-rag.md +366 -0
- package/content/series/ai/rag-thuc-chien/chapters/04-phan-4-advanced-rag/lessons/13-bai-12-rag-evaluation.md +318 -0
- package/content/series/ai/rag-thuc-chien/chapters/05-phan-5-production-capstone/lessons/14-bai-13-deploy-rag-production.md +395 -0
- package/content/series/ai/rag-thuc-chien/chapters/05-phan-5-production-capstone/lessons/15-bai-14-capstone.md +409 -0
- package/content/series/ai/rag-thuc-chien/index.md +285 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/02-bai-1-rl-la-gi.md +139 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/03-bai-2-dynamic-programming.md +139 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/04-bai-3-monte-carlo-td.md +154 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/05-bai-4-q-learning.md +148 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/06-bai-5-dqn.md +161 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/07-bai-6-policy-gradient.md +144 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/08-bai-7-ppo.md +130 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/09-bai-8-sac.md +126 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/03-phan-3-frameworks/lessons/10-bai-9-gymnasium.md +149 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/03-phan-3-frameworks/lessons/11-bai-10-custom-env.md +142 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/03-phan-3-frameworks/lessons/12-bai-11-robotics.md +116 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/13-bai-12-rlhf.md +122 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/14-bai-13-dpo.md +118 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/15-bai-14-multi-agent.md +120 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/16-bai-15-rl-production.md +153 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/17-bai-16-capstone.md +156 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/index.md +280 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/01-phan-1-nen-tang-xu-ly-am-thanh-tin-hieu/lessons/02-bai-1-digital-audio-signal-processing.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/01-phan-1-nen-tang-xu-ly-am-thanh-tin-hieu/lessons/03-bai-2-audio-feature-extraction.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/01-phan-1-nen-tang-xu-ly-am-thanh-tin-hieu/lessons/04-bai-3-audio-classification.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/02-phan-2-speech-recognition-asr-nhan-dang-giong-noi/lessons/05-bai-4-asr-architecture.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/02-phan-2-speech-recognition-asr-nhan-dang-giong-noi/lessons/06-bai-5-whisper-modern-asr.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/02-phan-2-speech-recognition-asr-nhan-dang-giong-noi/lessons/07-bai-6-realtime-asr-streaming.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/03-phan-3-text-to-speech-voice-technologies/lessons/08-bai-7-tts-tacotron-vits.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/03-phan-3-text-to-speech-voice-technologies/lessons/09-bai-8-voice-cloning.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/03-phan-3-text-to-speech-voice-technologies/lessons/10-bai-9-speaker-verification-diarization.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/11-bai-10-speech-enhancement.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/12-bai-11-music-ai.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/13-bai-12-emotion-recognition.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/14-bai-13-vietnamese-speech-ai.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/15-bai-14-deploy-speech-ai.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/16-bai-15-capstone-voice-assistant.md +53 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/index.md +208 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/01-phan-1-nen-tang-time-series-analysis/lessons/02-bai-1-time-series-fundamentals.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/01-phan-1-nen-tang-time-series-analysis/lessons/03-bai-2-arima-sarima-ets.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/01-phan-1-nen-tang-time-series-analysis/lessons/04-bai-3-prophet-forecasting.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/02-phan-2-machine-learning-cho-time-series/lessons/05-bai-4-feature-engineering.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/02-phan-2-machine-learning-cho-time-series/lessons/06-bai-5-xgboost-lightgbm.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/02-phan-2-machine-learning-cho-time-series/lessons/07-bai-6-multivariate-hierarchical.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/03-phan-3-deep-learning-cho-time-series/lessons/08-bai-7-lstm-sequence-models.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/03-phan-3-deep-learning-cho-time-series/lessons/09-bai-8-transformers-time-series.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/03-phan-3-deep-learning-cho-time-series/lessons/10-bai-9-foundation-models.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/11-bai-10-anomaly-detection.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/12-bai-11-classification-clustering.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/13-bai-12-financial-time-series.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/14-bai-13-production-pipeline.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/15-bai-14-capstone-forecasting.md +53 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/index.md +199 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/01-bai-1-tong-quan-kien-truc.md +287 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/02-bai-2-setup-typescript-monorepo.md +283 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/03-bai-3-dual-database.md +212 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/04-bai-4-api-gateway-hono.md +143 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/05-bai-5-llm-router.md +268 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/06-bai-6-tool-registry.md +208 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/07-bai-7-agent-class.md +248 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/08-bai-8-streaming-eventbus.md +234 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/03-phan-3-rag-pipeline/lessons/09-bai-9-document-processor.md +214 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/03-phan-3-rag-pipeline/lessons/10-bai-10-embedding-vector-store.md +236 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/03-phan-3-rag-pipeline/lessons/11-bai-11-rag-engine.md +240 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/04-phan-4-workflow-engine/lessons/12-bai-12-workflow-engine.md +222 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/04-phan-4-workflow-engine/lessons/13-bai-13-workflow-validation-execution.md +260 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/05-phan-5-skills-domains-plugins/lessons/14-bai-14-skill-system.md +224 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/05-phan-5-skills-domains-plugins/lessons/15-bai-15-domain-packs.md +220 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/05-phan-5-skills-domains-plugins/lessons/16-bai-16-plugin-mcp.md +304 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/06-phan-6-multi-tenant-rbac-channels/lessons/17-bai-17-multi-tenant-rbac.md +291 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/06-phan-6-multi-tenant-rbac-channels/lessons/18-bai-18-chat-channels.md +212 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/07-phan-7-frontend-monitoring-production/lessons/19-bai-19-react-frontend.md +1025 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/07-phan-7-frontend-monitoring-production/lessons/20-bai-20-monitoring-deploy.md +352 -0
- package/content/series/ai/xay-dung-ai-agent-platform/index.md +388 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/01-phan-1-cloud-native-foundations/lessons/01-bai-1-cloud-native-la-gi-nguyen-ly-va-twelve-factor-app.md +298 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/01-phan-1-cloud-native-foundations/lessons/02-bai-2-container-docker-nen-tang-dong-goi-ung-dung.md +364 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/01-phan-1-cloud-native-foundations/lessons/03-bai-3-kubernetes-architecture-core-concepts.md +460 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/04-bai-4-microservices-design-principles-srp-ddd-bounded-context.md +328 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/05-bai-5-synchronous-communication-rest-api-grpc.md +379 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/06-bai-6-asynchronous-communication-message-queue-event-streaming.md +303 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/07-bai-7-api-gateway-pattern-kong-apisix-envoy.md +314 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/08-bai-8-database-per-service-polyglot-persistence.md +270 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/09-bai-9-event-sourcing-cqrs.md +302 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/10-bai-10-saga-pattern-distributed-transactions.md +479 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/11-bai-11-data-consistency-patterns-outbox-cdc-eventual-consistency.md +445 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/04-phan-4-service-mesh-networking/lessons/12-bai-12-service-discovery-registry.md +459 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/04-phan-4-service-mesh-networking/lessons/13-bai-13-service-mesh-istio-linkerd.md +423 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/04-phan-4-service-mesh-networking/lessons/14-bai-14-zero-trust-security-mtls.md +444 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/05-phan-5-observability/lessons/15-bai-15-metrics-prometheus-grafana.md +541 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/05-phan-5-observability/lessons/16-bai-16-logging-structured-logging-loki-elk.md +510 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/05-phan-5-observability/lessons/17-bai-17-distributed-tracing-opentelemetry-jaeger.md +583 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/06-phan-6-resiliency-patterns/lessons/18-bai-18-circuit-breaker-retry-patterns.md +471 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/06-phan-6-resiliency-patterns/lessons/19-bai-19-bulkhead-rate-limiting-health-check-patterns.md +493 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/06-phan-6-resiliency-patterns/lessons/20-bai-20-chaos-engineering-kiem-chung-do-tin-cay.md +414 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/07-phan-7-cicd-deployment/lessons/21-bai-21-cicd-pipeline-cho-microservices.md +461 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/07-phan-7-cicd-deployment/lessons/22-bai-22-gitops-voi-argocd.md +499 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/07-phan-7-cicd-deployment/lessons/23-bai-23-deployment-strategies-canary-blue-green-progressive-delivery.md +496 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/08-phan-8-security-production-readiness/lessons/24-bai-24-authentication-authorization-oauth2-jwt-oidc.md +485 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/08-phan-8-security-production-readiness/lessons/25-bai-25-secrets-management-container-security.md +533 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/08-phan-8-security-production-readiness/lessons/26-bai-26-production-readiness-checklist-lo-trinh-trien-khai.md +499 -0
- package/content/series/architecture/cloud-native-microservices-architecture/index.md +396 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hl7-va-fhir/lessons/01-bai-1-gioi-thieu-hl7-va-lich-su-chuan-du-lieu-y-te.md +296 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hl7-va-fhir/lessons/02-bai-2-tong-quan-fhir-r5-kien-truc-va-nguyen-tac-thiet-ke.md +447 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hl7-va-fhir/lessons/03-bai-3-cai-dat-moi-truong-phat-trien-fhir.md +413 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/04-bai-4-patient-practitioner-organization-resources-hanh-chinh.md +446 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/05-bai-5-encounter-condition-observation-resources-lam-sang.md +548 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/06-bai-6-medication-medicationrequest-immunization-resources-thuoc.md +363 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/07-bai-7-diagnosticreport-procedure-allergyintolerance-resources-chan-doan.md +411 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/03-phan-3-fhir-restful-api-va-data-exchange/lessons/08-bai-8-fhir-restful-api-crud-search-history-va-versioning.md +324 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/03-phan-3-fhir-restful-api-va-data-exchange/lessons/09-bai-9-bundle-transaction-va-batch-xu-ly-nhieu-resources.md +319 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/03-phan-3-fhir-restful-api-va-data-exchange/lessons/10-bai-10-search-parameters-va-tim-kiem-nang-cao.md +219 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/04-phan-4-data-types-terminologies-va-profiles/lessons/11-bai-11-fhir-data-types-primitive-complex-va-special.md +318 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/04-phan-4-data-types-terminologies-va-profiles/lessons/12-bai-12-terminologies-codesystem-valueset-conceptmap.md +278 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/04-phan-4-data-types-terminologies-va-profiles/lessons/13-bai-13-profiles-extensions-va-implementation-guides.md +320 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/14-bai-14-fhir-documents-va-messaging.md +277 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/15-bai-15-fhir-subscriptions-va-real-time-notifications.md +250 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/16-bai-16-smart-on-fhir-oauth2-va-ung-dung-y-te.md +243 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/17-bai-17-security-privacy-va-consent-trong-fhir.md +358 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/18-bai-18-hands-on-xay-dung-fhir-server-voi-hapi-fhir.md +399 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/19-bai-19-hands-on-fhir-client-va-tich-hop-ung-dung.md +353 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/20-bai-20-hands-on-xay-dung-implementation-guide-cho-viet-nam.md +335 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/21-bai-21-hands-on-tich-hop-fhir-voi-emr-his-thuc-te.md +453 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/22-bai-22-fhir-performance-scalability-va-monitoring.md +353 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/23-bai-23-fhir-trong-boi-canh-y-te-viet-nam.md +244 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/24-bai-24-case-studies-us-core-ips-va-trien-khai-thuc-te.md +247 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/25-bai-25-tuong-lai-fhir-r6-ai-ml-genomics-va-xu-huong-moi.md +404 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/index.md +427 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/01-phan-1-data-platform-foundations/lessons/01-bai-1-tong-quan-data-platform-evolution-architecture-patterns.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/01-phan-1-data-platform-foundations/lessons/02-bai-2-data-lakehouse-architecture-iceberg-delta-lake-hudi.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/01-phan-1-data-platform-foundations/lessons/03-bai-3-data-mesh-domain-oriented-data-architecture.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/04-bai-4-batch-processing-etl-elt-voi-airflow-dbt.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/05-bai-5-stream-processing-kafka-flink-real-time-pipeline.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/06-bai-6-change-data-capture-cdc-debezium-event-sourcing.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/07-bai-7-data-integration-api-ingestion.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/03-phan-3-data-storage-modeling/lessons/08-bai-8-data-modeling-dimensional-modeling-activity-schema.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/03-phan-3-data-storage-modeling/lessons/09-bai-9-storage-layer-object-storage-columnar-formats-partitioning.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/03-phan-3-data-storage-modeling/lessons/10-bai-10-query-engines-trino-duckdb-materialized-views.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/11-bai-11-data-quality-framework-testing-monitoring-alerting.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/12-bai-12-data-catalog-discovery-metadata-management.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/13-bai-13-data-governance-access-control.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/14-bai-14-data-contracts-schema-evolution.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/05-phan-5-analytics-semantic-layer/lessons/15-bai-15-semantic-layer-metrics-store-business-logic.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/05-phan-5-analytics-semantic-layer/lessons/16-bai-16-bi-visualization-dashboard-architecture.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/05-phan-5-analytics-semantic-layer/lessons/17-bai-17-real-time-analytics-clickhouse-streaming-dashboards.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/06-phan-6-ml-data-platform/lessons/18-bai-18-feature-store-feature-engineering-at-scale.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/06-phan-6-ml-data-platform/lessons/19-bai-19-ml-pipeline-integration-training-serving-data.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/06-phan-6-ml-data-platform/lessons/20-bai-20-reverse-etl-operational-analytics.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/21-bai-21-infrastructure-cost-optimization.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-data-platform-security-privacy.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-dataops-platform-engineering.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-observability-cho-data-platform.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-uber-netflix-airbnb-spotify.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/index.md +318 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/01-phan-1-edtech-foundations/lessons/01-bai-1-tong-quan-edtech-domain-analysis-business-models.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/01-phan-1-edtech-foundations/lessons/02-bai-2-lms-platform-architecture-microservices-ddd.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/01-phan-1-edtech-foundations/lessons/03-bai-3-learning-standards-scorm-xapi-lti.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/04-bai-4-course-management-system-curriculum-enrollment.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/05-bai-5-content-authoring-rich-media.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/06-bai-6-video-delivery-hls-dash-adaptive-streaming.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/07-bai-7-live-class-webinar-architecture.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/08-bai-8-assessment-engine-question-bank-quiz-system.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/09-bai-9-coding-assessment-auto-grading.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/10-bai-10-gamification-engine-points-badges-leaderboards.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/11-bai-11-certificate-engine-credential-verification.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/04-phan-4-personalization-ai/lessons/12-bai-12-adaptive-learning-personalized-learning-paths.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/04-phan-4-personalization-ai/lessons/13-bai-13-ai-tutor-learning-assistant.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/04-phan-4-personalization-ai/lessons/14-bai-14-recommendation-engine-what-to-learn-next.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/05-phan-5-collaboration-community/lessons/15-bai-15-real-time-collaboration-shared-workspace.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/05-phan-5-collaboration-community/lessons/16-bai-16-discussion-forum-social-learning.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/05-phan-5-collaboration-community/lessons/17-bai-17-notification-engagement-engine.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/06-phan-6-analytics-business/lessons/18-bai-18-learning-analytics-tracking-insights.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/06-phan-6-analytics-business/lessons/19-bai-19-marketplace-instructor-platform.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/06-phan-6-analytics-business/lessons/20-bai-20-payment-subscription-cho-edtech.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/21-bai-21-mobile-first-architecture-offline-learning.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-scalability-performance-cho-edtech.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-security-privacy-cho-edtech.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-accessibility-internationalization.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-coursera-udemy-duolingo-khan-academy.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/index.md +314 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/01-phan-1-foundation-platform-overview/lessons/01-bai-1-tong-quan-enterprise-ai-chatbot.md +234 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/01-phan-1-foundation-platform-overview/lessons/02-bai-2-platform-architecture-overview.md +396 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/01-phan-1-foundation-platform-overview/lessons/03-bai-3-multi-model-gateway.md +663 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/01-bai-4-conversation-management.md +486 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/02-bai-5-rag-pipeline.md +450 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/03-bai-6-prompt-engineering-engine.md +396 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/04-bai-7-streaming-realtime.md +557 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/01-bai-8-function-calling-tool-use.md +409 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/02-bai-9-multi-agent-orchestration.md +423 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/03-bai-10-planning-reflection.md +463 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/04-bai-11-structured-data-querying.md +382 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/01-bai-12-guardrails-ai-safety.md +396 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/02-bai-13-knowledge-base-management.md +376 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/03-bai-14-multi-tenant-architecture.md +345 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/04-bai-15-analytics-observability.md +350 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/01-bai-16-multi-channel-integration.md +381 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/02-bai-17-human-handoff-hybrid-support.md +384 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/03-bai-18-chatbot-evaluation-testing.md +355 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/04-bai-19-personalization-long-term-memory.md +405 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/06-phan-6-advanced-ai-capabilities/lessons/01-bai-20-domain-specific-ai.md +330 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/06-phan-6-advanced-ai-capabilities/lessons/02-bai-21-multimodal-ai.md +364 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/06-phan-6-advanced-ai-capabilities/lessons/03-bai-22-workflow-automation.md +526 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/07-phan-7-infrastructure-security-production/lessons/01-bai-23-gpu-infrastructure.md +473 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/07-phan-7-infrastructure-security-production/lessons/02-bai-24-security-compliance.md +510 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/07-phan-7-infrastructure-security-production/lessons/03-bai-25-case-studies.md +721 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/index.md +407 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/01-phan-1-event-driven-foundations/lessons/01-bai-1-tong-quan-event-driven-architecture-why-events-matter.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/01-phan-1-event-driven-foundations/lessons/02-bai-2-domain-events-event-modeling.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/01-phan-1-event-driven-foundations/lessons/03-bai-3-messaging-patterns-pub-sub-queue-stream.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/04-bai-4-kafka-architecture-brokers-partitions-replication.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/05-bai-5-kafka-producers-consumers-advanced-patterns.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/06-bai-6-kafka-streams-ksqldb.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/07-bai-7-schema-registry-data-serialization.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/08-bai-8-event-sourcing-immutable-event-log-source-of-truth.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/09-bai-9-cqrs-command-query-responsibility-segregation.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/10-bai-10-event-store-implementation-postgresql-eventstoredb.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/11-bai-11-projections-read-model-patterns.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/12-bai-12-saga-pattern-managing-distributed-transactions.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/13-bai-13-outbox-pattern-reliable-event-publishing.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/14-bai-14-dead-letter-queue-error-handling.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/15-bai-15-idempotency-exactly-once-processing.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/16-bai-16-event-driven-microservices-communication-patterns.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/17-bai-17-event-driven-data-consistency-conflict-resolution.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/18-bai-18-event-versioning-schema-evolution.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/19-bai-19-process-manager-workflow-engine.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/06-phan-6-operations-production/lessons/20-bai-20-kafka-operations-monitoring-tuning-troubleshooting.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/06-phan-6-operations-production/lessons/21-bai-21-testing-event-driven-systems.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/06-phan-6-operations-production/lessons/22-bai-22-observability-cho-event-driven-systems.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/07-phan-7-case-studies/lessons/23-bai-23-migration-to-event-driven-strangler-fig-pattern.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/07-phan-7-case-studies/lessons/24-bai-24-apache-pulsar-alternatives.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/07-phan-7-case-studies/lessons/25-bai-25-case-studies-uber-wix-booking-com-linkedin.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/index.md +316 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/01-phan-1-nen-tang-fintech-payment/lessons/01-bai-1-tong-quan-fintech-domain-analysis-business-models.md +331 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/01-phan-1-nen-tang-fintech-payment/lessons/02-bai-2-platform-architecture-overview-microservices-ddd-cho-fintech.md +399 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/01-phan-1-nen-tang-fintech-payment/lessons/03-bai-3-regulatory-compliance-pci-dss-psd2-quy-dinh-nhnn.md +319 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/04-bai-4-payment-gateway-architecture-luong-thanh-toan-end-to-end.md +408 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/05-bai-5-payment-processing-authorization-capture-settlement.md +349 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/06-bai-6-multi-psp-integration-vnpay-momo-zalopay-stripe.md +267 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/07-bai-7-reconciliation-settlement-engine.md +257 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/08-bai-8-digital-wallet-architecture-e-wallet-balance-management.md +277 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/09-bai-9-double-entry-ledger-system-accounting-engine.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/10-bai-10-transaction-processing-acid-idempotency-saga-pattern.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/11-bai-11-currency-exchange-rate-engine-multi-currency.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/04-phan-4-risk-management-fraud-detection/lessons/12-bai-12-fraud-detection-system-rule-engine-ml-models.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/04-phan-4-risk-management-fraud-detection/lessons/13-bai-13-anti-money-laundering-aml-kyc-pipeline.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/04-phan-4-risk-management-fraud-detection/lessons/14-bai-14-risk-scoring-real-time-transaction-monitoring.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/15-bai-15-core-banking-architecture-account-management.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/16-bai-16-lending-platform-loan-origination-underwriting.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/17-bai-17-credit-scoring-engine-data-pipeline-ml.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/18-bai-18-interest-calculation-amortization-engine.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/06-phan-6-data-platform-analytics/lessons/19-bai-19-financial-data-pipeline-event-streaming-cdc.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/06-phan-6-data-platform-analytics/lessons/20-bai-20-reporting-business-intelligence-regulatory-reports.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/06-phan-6-data-platform-analytics/lessons/21-bai-21-real-time-analytics-dashboard.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/22-bai-22-security-architecture-encryption-hsm-tokenization.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/23-bai-23-infrastructure-high-availability-multi-region-dr.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/24-bai-24-performance-scalability-handling-peak-transactions.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/25-bai-25-case-studies-vnpay-momo-grabpay-stripe.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/index.md +402 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/01-phan-1-tong-quan-domain-fashion-pod/lessons/01-bai-1-tong-quan-fashion-design-print-on-demand.md +169 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/01-phan-1-tong-quan-domain-fashion-pod/lessons/02-bai-2-product-lifecycle-design-workflow.md +265 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/01-phan-1-tong-quan-domain-fashion-pod/lessons/03-bai-3-system-architecture-overview.md +298 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/01-bai-4-design-studio-canvas-editor.md +374 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/02-bai-5-ai-design-generation.md +435 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/03-bai-6-ai-pattern-textile-design.md +350 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/04-bai-7-mockup-engine-3d-visualization.md +407 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/01-bai-8-product-catalog-sku-architecture.md +349 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/02-bai-9-multi-channel-sales-integration.md +329 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/03-bai-10-pricing-engine-revenue-model.md +349 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/04-bai-11-cart-checkout-payment.md +373 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/01-bai-12-order-management-system.md +372 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/02-bai-13-print-production-pipeline.md +329 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/03-bai-14-supplier-network-routing-engine.md +355 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/04-bai-15-shipping-logistics.md +355 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/05-phan-5-ai-intelligence-personalization/lessons/01-bai-16-ai-recommendation-personalization.md +294 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/05-phan-5-ai-intelligence-personalization/lessons/02-bai-17-ai-quality-control.md +344 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/05-phan-5-ai-intelligence-personalization/lessons/03-bai-18-ai-trend-forecasting-demand-prediction.md +353 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/06-phan-6-data-platform-analytics/lessons/01-bai-19-data-architecture-event-streaming.md +358 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/06-phan-6-data-platform-analytics/lessons/02-bai-20-analytics-dashboard.md +134 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/06-phan-6-data-platform-analytics/lessons/03-bai-21-ml-pipeline-feature-store.md +160 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/01-bai-22-infrastructure-devops-kubernetes.md +96 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/02-bai-23-performance-scaling.md +127 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/03-bai-24-security-ip-protection-compliance.md +135 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/04-bai-25-case-studies-industry-analysis.md +130 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/index.md +402 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/01-phan-1-saas-foundations/lessons/01-bai-1-tong-quan-saas-business-models-metrics-architecture.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/01-phan-1-saas-foundations/lessons/02-bai-2-multi-tenancy-deep-dive-isolation-strategies-trade-offs.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/01-phan-1-saas-foundations/lessons/03-bai-3-platform-architecture-overview-ddd-microservices-cho-saas.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/04-bai-4-tenant-lifecycle-management-provisioning-configuration.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/05-bai-5-identity-access-management-multi-tenant-auth-sso.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/06-bai-6-onboarding-engine-self-service-signup-guided-setup.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/07-bai-7-data-isolation-multi-tenant-database-patterns.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/03-phan-3-billing-subscription-engine/lessons/08-bai-8-subscription-engine-plans-pricing-lifecycle.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/03-phan-3-billing-subscription-engine/lessons/09-bai-9-usage-metering-billing-engine.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/03-phan-3-billing-subscription-engine/lessons/10-bai-10-entitlement-system-feature-gating.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/11-bai-11-feature-flags-configuration-management.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/12-bai-12-plugin-extension-architecture-marketplace.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/13-bai-13-white-labeling-custom-branding.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/14-bai-14-notification-communication-engine.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/15-bai-15-api-design-developer-experience.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/16-bai-16-data-import-export-migration-tools.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/17-bai-17-search-analytics-per-tenant.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/18-bai-18-audit-logging-compliance.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/06-phan-6-scaling-operations/lessons/19-bai-19-noisy-neighbor-resource-isolation.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/06-phan-6-scaling-operations/lessons/20-bai-20-multi-region-deployment-data-residency.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/06-phan-6-scaling-operations/lessons/21-bai-21-tenant-aware-cicd-infrastructure-automation.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-observability-sre-cho-multi-tenant.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-security-architecture-cho-saas.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-admin-portal-self-service-operations.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-slack-notion-atlassian-linear.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/index.md +314 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/01-phan-1-platform-engineering-foundations/lessons/01-bai-1-tong-quan-platform-engineering-why-what-how.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/01-phan-1-platform-engineering-foundations/lessons/02-bai-2-developer-experience-dx-measuring-improving.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/01-phan-1-platform-engineering-foundations/lessons/03-bai-3-platform-architecture-overview-layers-components.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/04-bai-4-backstage-internal-developer-portal.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/05-bai-5-service-catalog-software-templates.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/06-bai-6-api-portal-documentation.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/07-bai-7-golden-paths-paved-roads.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/08-bai-8-self-service-infrastructure-provisioning-management.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/09-bai-9-infrastructure-as-code-terraform-crossplane-pulumi.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/10-bai-10-environment-management-dev-staging-production.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/11-bai-11-database-middleware-self-service.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/12-bai-12-cicd-platform-architecture-pipeline-as-code.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/13-bai-13-gitops-deployment-automation.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/14-bai-14-container-image-management.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/15-bai-15-testing-platform-shift-left-quality-gates.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/05-phan-5-security-compliance-platform/lessons/16-bai-16-security-platform-policy-as-code.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/05-phan-5-security-compliance-platform/lessons/17-bai-17-supply-chain-security-sbom-slsa.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/05-phan-5-security-compliance-platform/lessons/18-bai-18-cost-management-finops-platform.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/06-phan-6-observability-platform/lessons/19-bai-19-observability-platform-metrics-logs-traces.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/06-phan-6-observability-platform/lessons/20-bai-20-sre-platform-slo-error-budgets-incident-management.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/06-phan-6-observability-platform/lessons/21-bai-21-logging-audit-platform.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-platform-team-organization-operating-model.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-platform-migration-adoption.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-measuring-platform-success-metrics-roi.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-spotify-netflix-airbnb-mercado-libre.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/index.md +316 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/01-phan-1-iot-foundations/lessons/01-bai-1-tong-quan-iot-platform-architecture-ecosystem.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/01-phan-1-iot-foundations/lessons/02-bai-2-iot-protocols-mqtt-coap-amqp-websocket.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/01-phan-1-iot-foundations/lessons/03-bai-3-platform-architecture-overview-cloud-edge-hybrid.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/04-bai-4-device-management-provisioning-registry-lifecycle.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/05-bai-5-iot-security-device-authentication-encryption.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/06-bai-6-ota-updates-remote-configuration.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/07-bai-7-gateway-architecture-protocol-translation.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/03-phan-3-edge-computing/lessons/08-bai-8-edge-computing-architecture-processing-at-the-edge.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/03-phan-3-edge-computing/lessons/09-bai-9-edge-ai-on-device-inference.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/03-phan-3-edge-computing/lessons/10-bai-10-edge-cloud-synchronization-offline-mode.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/04-phan-4-data-processing-storage/lessons/11-bai-11-time-series-database-timescaledb-influxdb-questdb.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/04-phan-4-data-processing-storage/lessons/12-bai-12-iot-data-pipeline-ingestion-processing-storage.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/04-phan-4-data-processing-storage/lessons/13-bai-13-rule-engine-complex-event-processing.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/05-phan-5-digital-twin-visualization/lessons/14-bai-14-digital-twin-architecture-virtual-representation.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/05-phan-5-digital-twin-visualization/lessons/15-bai-15-real-time-monitoring-dashboard-visualization.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/05-phan-5-digital-twin-visualization/lessons/16-bai-16-predictive-maintenance-anomaly-detection.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/17-bai-17-smart-factory-industrial-iot-iiot-architecture.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/18-bai-18-smart-building-energy-management.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/19-bai-19-connected-vehicles-fleet-management.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/20-bai-20-agriculture-iot-environmental-monitoring.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/21-bai-21-scalability-handling-millions-of-devices.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-iot-platform-on-kubernetes.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-iot-data-analytics-machine-learning.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-observability-monitoring-cho-iot-platform.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-aws-iot-azure-iot-bosch-iot.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/index.md +314 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/01-phan-1-tong-quan-ohdsi-omop-cdm/lessons/01-bai-1-ohdsi-la-gi-tong-quan-he-sinh-thai-va-tam-nhin.md +275 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/01-phan-1-tong-quan-ohdsi-omop-cdm/lessons/02-bai-2-omop-cdm-cau-truc-nguyen-ly-domain.md +439 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/01-phan-1-tong-quan-ohdsi-omop-cdm/lessons/03-bai-3-athena-tra-cuu-quan-ly-standardized-vocabularies.md +390 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/02-phan-2-etl-chuan-hoa-du-lieu/lessons/04-bai-4-whiterabbit-rabbit-in-a-hat-khao-sat-du-lieu-thiet-ke-etl.md +326 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/02-phan-2-etl-chuan-hoa-du-lieu/lessons/05-bai-5-usagi-mapping-ma-nguon-sang-omop-standard-concepts.md +327 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/02-phan-2-etl-chuan-hoa-du-lieu/lessons/06-bai-6-xay-dung-etl-pipeline-tu-du-lieu-nguon-sang-omop-cdm.md +452 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/03-phan-3-trien-khai-platform/lessons/07-bai-7-cai-dat-omop-cdm-database-tren-postgresql.md +400 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/03-phan-3-trien-khai-platform/lessons/08-bai-8-webapi-cai-dat-cau-hinh-rest-api.md +395 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/03-phan-3-trien-khai-platform/lessons/09-bai-9-atlas-cai-dat-tich-hop-webapi-giao-dien-tong-quan.md +300 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/04-phan-4-phan-tich-du-lieu-atlas/lessons/10-bai-10-atlas-concept-sets-cohort-definitions.md +341 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/04-phan-4-phan-tich-du-lieu-atlas/lessons/11-bai-11-atlas-characterization-incidence-rates-pathways.md +310 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/04-phan-4-phan-tich-du-lieu-atlas/lessons/12-bai-12-atlas-population-level-estimation-patient-level-prediction.md +453 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/05-phan-5-data-quality-advanced-analytics/lessons/13-bai-13-achilles-data-characterization-source-profiling.md +382 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/05-phan-5-data-quality-advanced-analytics/lessons/14-bai-14-data-quality-dashboard-danh-gia-chat-luong-du-lieu-cdm.md +409 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/05-phan-5-data-quality-advanced-analytics/lessons/15-bai-15-hades-r-packages-cho-nghien-cuu-quan-sat.md +537 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/06-phan-6-production-network-studies/lessons/16-bai-16-trien-khai-ohdsi-stack-tren-docker-kubernetes.md +650 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/06-phan-6-production-network-studies/lessons/17-bai-17-network-studies-best-practices-nghien-cuu-da-trung-tam.md +520 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/index.md +341 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/01-bai-1-system-design-la-gi-tong-quan-va-roadmap.md +310 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/02-bai-2-performance-vs-scalability.md +310 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/03-bai-3-latency-throughput-availability-consistency.md +355 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/04-bai-4-networking-fundamentals.md +318 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/05-bai-5-load-balancer.md +339 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/06-bai-6-cdn.md +222 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/07-bai-7-caching-strategies.md +279 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/08-bai-8-reverse-proxy-api-gateway.md +268 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/09-bai-9-sql-vs-nosql.md +252 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/10-bai-10-database-replication.md +268 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/11-bai-11-database-sharding.md +294 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/12-bai-12-data-storage-patterns.md +310 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/04-phan-4-async-processing/lessons/13-bai-13-message-queues.md +289 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/04-phan-4-async-processing/lessons/14-bai-14-event-driven-architecture.md +319 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/04-phan-4-async-processing/lessons/15-bai-15-stream-processing.md +309 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/16-bai-16-monolith-to-microservices.md +292 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/17-bai-17-service-communication.md +328 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/18-bai-18-domain-driven-design.md +317 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/19-bai-19-serverless-cloud-native.md +291 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/20-bai-20-high-availability.md +274 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/21-bai-21-disaster-recovery.md +281 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/22-bai-22-security-architecture.md +309 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/23-bai-23-observability.md +356 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/24-bai-24-url-shortener.md +257 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/25-bai-25-chat-system.md +266 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/26-bai-26-news-feed.md +252 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/27-bai-27-video-streaming.md +271 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/28-bai-28-ride-sharing.md +290 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/29-bai-29-e-commerce.md +311 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/08-phan-8-production-ready/lessons/30-bai-30-architecture-decision-records.md +361 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/index.md +486 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/01-phan-1-nen-tang-evolution-of-architecture/lessons/01-bai-1-tu-monolith-den-microservices-micro-frontend.md +238 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/01-phan-1-nen-tang-evolution-of-architecture/lessons/02-bai-2-domain-driven-design-tu-duy-phan-tach-he-thong.md +259 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/01-phan-1-nen-tang-evolution-of-architecture/lessons/03-bai-3-kien-truc-tong-quan-full-stack.md +160 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/02-phan-2-thiet-ke-microservices-backend/lessons/04-bai-4-service-decomposition.md +195 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/02-phan-2-thiet-ke-microservices-backend/lessons/05-bai-5-api-design-masterclass.md +211 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/02-phan-2-thiet-ke-microservices-backend/lessons/06-bai-6-inter-service-communication.md +185 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/03-phan-3-data-architecture/lessons/07-bai-7-database-per-service.md +153 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/03-phan-3-data-architecture/lessons/08-bai-8-saga-pattern.md +176 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/03-phan-3-data-architecture/lessons/09-bai-9-event-sourcing-cqrs.md +171 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/04-phan-4-micro-frontend-kien-truc-nguyen-ly/lessons/10-bai-10-micro-frontend-la-gi.md +141 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/04-phan-4-micro-frontend-kien-truc-nguyen-ly/lessons/11-bai-11-integration-strategies.md +141 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/04-phan-4-micro-frontend-kien-truc-nguyen-ly/lessons/12-bai-12-module-federation-deep-dive.md +203 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/13-bai-13-shell-application.md +169 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/14-bai-14-state-management.md +157 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/15-bai-15-design-system.md +134 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/16-bai-16-authentication-sso.md +159 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/06-phan-6-api-gateway-bff-layer/lessons/17-bai-17-bff-pattern.md +174 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/06-phan-6-api-gateway-bff-layer/lessons/18-bai-18-api-gateway.md +224 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/06-phan-6-api-gateway-bff-layer/lessons/19-bai-19-graphql-federation.md +223 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/07-phan-7-testing-full-stack/lessons/20-bai-20-testing-microservices.md +222 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/07-phan-7-testing-full-stack/lessons/21-bai-21-testing-micro-frontend.md +185 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/07-phan-7-testing-full-stack/lessons/22-bai-22-contract-testing.md +212 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/08-phan-8-cicd-deployment-strategies/lessons/23-bai-23-mono-repo-vs-multi-repo.md +198 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/08-phan-8-cicd-deployment-strategies/lessons/24-bai-24-cicd-pipeline.md +249 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/08-phan-8-cicd-deployment-strategies/lessons/25-bai-25-deployment-strategies.md +213 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/09-phan-9-observability-production-readiness/lessons/26-bai-26-observability.md +207 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/09-phan-9-observability-production-readiness/lessons/27-bai-27-performance-optimization.md +218 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/09-phan-9-observability-production-readiness/lessons/28-bai-28-production-readiness.md +242 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/10-phan-10-case-studies-migration/lessons/29-bai-29-case-study-ecommerce.md +219 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/10-phan-10-case-studies-migration/lessons/30-bai-30-migration-guide.md +281 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/index.md +550 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/01-phan-1-nen-tang-bai-toan-notification/lessons/01-bai-1-tong-quan-he-thong-notification-bai-toan-gui-trieu-email.md +200 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/01-phan-1-nen-tang-bai-toan-notification/lessons/02-bai-2-kien-truc-tong-quan-high-level-design.md +369 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/01-phan-1-nen-tang-bai-toan-notification/lessons/03-bai-3-design-patterns-cho-email-system-quy-mo-lon.md +375 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/02-phan-2-message-queue-event-driven/lessons/04-bai-4-message-queue-xuong-song-cua-notification-system.md +355 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/02-phan-2-message-queue-event-driven/lessons/05-bai-5-event-driven-notification-pipeline-voi-kafka.md +434 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/02-phan-2-message-queue-event-driven/lessons/06-bai-6-priority-queue-va-scheduling-engine.md +388 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/03-phan-3-email-infrastructure/lessons/07-bai-7-smtp-deep-dive-hieu-email-delivery-tu-goc.md +372 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/03-phan-3-email-infrastructure/lessons/08-bai-8-email-service-providers-ses-sendgrid-mailgun.md +434 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/03-phan-3-email-infrastructure/lessons/09-bai-9-template-engine-va-content-pipeline.md +431 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/04-phan-4-xu-ly-quy-mo-scaling-to-millions/lessons/10-bai-10-rate-limiting-throttling-kiem-soat-toc-do-gui.md +267 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/04-phan-4-xu-ly-quy-mo-scaling-to-millions/lessons/11-bai-11-batch-processing-worker-pool-architecture.md +294 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/04-phan-4-xu-ly-quy-mo-scaling-to-millions/lessons/12-bai-12-retry-dead-letter-queue-error-handling.md +272 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/05-phan-5-deliverability-monitoring-production/lessons/13-bai-13-email-deliverability-spf-dkim-dmarc.md +235 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/05-phan-5-deliverability-monitoring-production/lessons/14-bai-14-monitoring-metrics-alerting.md +258 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/05-phan-5-deliverability-monitoring-production/lessons/15-bai-15-production-deployment-case-study-gui-10-trieu-email.md +289 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/index.md +313 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/01-bai-1-tong-quan-bao-mat-du-lieu-y-te-hipaa-hl7-fhir.md +317 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/02-bai-2-kien-truc-microservices-an-toan-cho-y-te.md +574 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/03-bai-3-phan-loai-du-lieu-y-te-phi-va-danh-gia-rui-ro.md +375 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/04-bai-4-threat-modeling-stride-dread-cho-his.md +491 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/01-bai-5-thiet-ke-keycloak-realm-chuan-y-te.md +515 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/02-bai-6-rbac-abac-phan-quyen-nhan-vien-y-te.md +494 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/03-bai-7-smart-on-fhir-oauth2-oidc-healthcare-apis.md +497 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/04-bai-8-mfa-passkeys-emergency-access-nhan-vien-y-te.md +405 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/01-bai-9-postgresql-security-hardening-toan-dien.md +1036 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/02-bai-10-ma-hoa-du-lieu-at-rest-in-transit-postgresql.md +1028 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/03-bai-11-row-level-security-column-encryption-phi.md +1093 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/04-bai-12-audit-logging-cdc-pgaudit.md +1226 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/01-bai-13-quarkus-security-oidc-jwt-rbac.md +1317 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/02-bai-14-api-gateway-rate-limiting-waf.md +1287 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/03-bai-15-ma-hoa-du-lieu-end-to-end-microservices.md +1232 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/04-bai-16-mtls-service-mesh-inter-service-communication.md +1387 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/01-bai-17-hipaa-technical-safeguards-implementation.md +1500 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/02-bai-18-centralized-audit-trail-opentelemetry-elk.md +1415 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/03-bai-19-data-masking-anonymization-de-identification.md +1376 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/04-bai-20-backup-dr-business-continuity-du-lieu-y-te.md +1351 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/01-bai-21-zero-trust-architecture-he-thong-y-te.md +1507 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/02-bai-22-container-kubernetes-security-healthcare.md +1521 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/03-bai-23-penetration-testing-vulnerability-assessment-y-te.md +1697 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/04-bai-24-capstone-xay-dung-secure-healthcare-platform.md +1881 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/index.md +441 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/01-bai-1-tong-quan-kien-truc-microservices-on-premises.md +964 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/02-bai-2-lap-ke-hoach-phan-cung-va-network-topology.md +1019 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/03-bai-3-chuan-bi-linux-os-va-system-tuning.md +731 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/04-bai-4-load-balancer-cho-kubernetes-api-server.md +708 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/01-bai-5-cai-dat-containerd-va-kubeadm.md +410 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/02-bai-6-khoi-tao-kubernetes-ha-control-plane.md +449 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/03-bai-7-join-them-control-plane-va-worker-nodes.md +356 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/04-bai-8-cai-dat-cilium-cni.md +547 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/05-bai-9-metallb-loadbalancer-cho-on-premises.md +369 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/06-bai-10-etcd-van-hanh-backup-va-disaster-recovery.md +546 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/01-bai-11-kien-truc-distributed-storage-voi-rook-ceph.md +426 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/02-bai-12-cai-dat-rook-ceph-operator-va-cephcluster.md +383 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/03-bai-13-cephblockpool-storageclass-va-pvc.md +392 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/04-bai-14-cephfs-shared-filesystem-cho-readwritemany.md +307 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/05-bai-15-ceph-monitoring-tuning-va-troubleshooting.md +329 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/01-bai-16-kien-truc-postgresql-ha-voi-patroni-va-cloudnativepg.md +302 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/02-bai-17-deploy-cloudnativepg-operator-va-postgresql-cluster.md +367 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/03-bai-18-postgresql-backup-pitr-va-disaster-recovery.md +319 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/04-bai-19-postgresql-failover-testing-va-switchover.md +277 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/05-bai-20-postgresql-monitoring-tuning-va-day-2-operations.md +409 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/05-phan-5-message-queue-ha/lessons/01-bai-21-rabbitmq-ha-cluster-tren-kubernetes.md +487 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/05-phan-5-message-queue-ha/lessons/02-bai-22-apache-kafka-cluster-voi-strimzi-operator.md +573 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/05-phan-5-message-queue-ha/lessons/03-bai-23-redis-ha-sentinel-va-cluster-mode.md +482 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/01-bai-24-kien-truc-istio-service-mesh.md +364 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/02-bai-25-istio-traffic-management.md +375 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/03-bai-26-istio-gateway-va-ingress.md +385 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/04-bai-27-istio-security-authorizationpolicy.md +350 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/01-bai-28-gitops-voi-argocd.md +396 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/02-bai-29-helm-charts-cho-microservices.md +423 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/03-bai-30-secrets-management-vault.md +368 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/04-bai-31-cicd-pipeline-gitops.md +345 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/01-bai-32-prometheus-stack-monitoring.md +409 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/02-bai-33-loki-centralized-logging.md +337 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/03-bai-34-tempo-distributed-tracing.md +388 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/04-bai-35-grafana-dashboards-va-slo-monitoring.md +347 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/01-bai-36-rbac-va-pod-security-standards.md +314 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/02-bai-37-kyverno-policy-engine.md +402 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/03-bai-38-falco-runtime-security.md +307 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/04-bai-39-harbor-registry-va-image-security.md +350 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/01-bai-40-canary-va-blue-green-deployment.md +320 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/02-bai-41-horizontal-va-vertical-pod-autoscaling.md +343 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/03-bai-42-resource-management-va-scheduling.md +301 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/04-bai-43-multi-tenancy-va-namespace-isolation.md +316 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/11-phan-11-disaster-recovery-chaos-engineering/lessons/01-bai-44-disaster-recovery-va-backup-strategies.md +309 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/11-phan-11-disaster-recovery-chaos-engineering/lessons/02-bai-45-chaos-engineering-voi-litmus.md +325 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/01-bai-46-production-readiness-checklist.md +183 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/02-bai-47-day-2-operations-va-maintenance.md +302 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/03-bai-48-performance-testing-va-optimization.md +284 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/04-bai-49-troubleshooting-guide.md +256 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/05-bai-50-capstone-project-ecommerce-microservices.md +289 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/index.md +851 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/01-bai-1-gioi-thieu-docker-container-va-virtualization.md +229 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/02-bai-2-cai-dat-docker-va-cac-lenh-co-ban.md +242 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/03-bai-3-docker-images-build-pull-va-quan-ly.md +230 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/04-bai-4-docker-containers-vong-doi-va-quan-ly.md +256 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/05-bai-5-dockerfile-tu-a-den-z.md +330 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/06-bai-6-multi-stage-builds-va-toi-uu-docker-image.md +243 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/07-bai-7-docker-registry-docker-hub-va-private-registry.md +184 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/08-bai-8-docker-compose-co-ban.md +324 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/09-bai-9-docker-networking-deep-dive.md +192 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/10-bai-10-docker-volumes-va-persistent-storage.md +254 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/11-bai-11-docker-compose-nang-cao.md +297 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/12-bai-12-environment-variables-secrets-va-configuration.md +245 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/13-bai-13-docker-security-best-practices.md +249 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/14-bai-14-docker-logging-va-monitoring.md +316 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/15-bai-15-docker-trong-ci-cd-pipeline.md +298 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/16-bai-16-docker-performance-tuning.md +238 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/17-bai-17-docker-swarm-container-orchestration.md +347 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/18-bai-18-docker-cho-microservices-architecture.md +434 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/19-bai-19-docker-voi-kubernetes-migration-path.md +408 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/20-bai-20-production-deployment-va-troubleshooting.md +602 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/index.md +519 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/01-bai-1-gioi-thieu-hashicorp-vault-secret-management-trong-enterprise.md +200 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/02-bai-2-cai-dat-vault-standalone-docker-va-kubernetes.md +217 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/03-bai-3-vault-cli-api-va-web-ui.md +151 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/04-bai-4-seal-unseal-auto-unseal-va-recovery-keys.md +866 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/05-bai-5-tokens-leases-va-renewal.md +985 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/06-bai-6-kv-secrets-engine-static-secrets-management.md +642 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/07-bai-7-database-secrets-engine-dynamic-credentials.md +645 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/08-bai-8-pki-secrets-engine-certificate-authority.md +708 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/09-bai-9-transit-secrets-engine-encryption-as-a-service.md +703 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/10-bai-10-aws-azure-gcp-va-cloud-secrets-engines.md +753 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/11-bai-11-auth-methods-co-ban-token-userpass-va-approle.md +553 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/12-bai-12-ldap-oidc-va-jwt-auth-methods.md +397 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/13-bai-13-kubernetes-aws-va-cloud-auth-methods.md +329 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/14-bai-14-policies-acl-sentinel-va-rbac.md +388 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/15-bai-15-identity-secrets-engine-entities-va-mfa.md +314 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/04-phan-4-secrets-engines-nang-cao/lessons/16-bai-16-ssh-secrets-engine-va-totp.md +256 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/04-phan-4-secrets-engines-nang-cao/lessons/17-bai-17-transform-va-tokenization-data-protection.md +238 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/04-phan-4-secrets-engines-nang-cao/lessons/18-bai-18-kmip-consul-nomad-secrets-engines-va-custom-plugins.md +292 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/05-phan-5-vault-agent-proxy-va-kubernetes-integration/lessons/19-bai-19-vault-agent-va-vault-proxy.md +396 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/05-phan-5-vault-agent-proxy-va-kubernetes-integration/lessons/20-bai-20-vault-tren-kubernetes-helm-operator-va-csi.md +407 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/21-bai-21-tich-hop-vault-voi-spring-boot-va-nodejs.md +313 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/22-bai-22-vault-voi-terraform-ansible-va-cicd-pipelines.md +408 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-enterprise-va-van-hanh/lessons/23-bai-23-high-availability-integrated-storage-va-production-hardening.md +334 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-enterprise-va-van-hanh/lessons/24-bai-24-vault-enterprise-namespaces-replication-va-dr.md +255 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-enterprise-va-van-hanh/lessons/25-bai-25-monitoring-audit-logging-backup-restore-va-troubleshooting.md +366 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/index.md +655 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/01-bai-1-gioi-thieu-keycloak-iam-va-sso-trong-enterprise.md +237 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/02-bai-2-cai-dat-keycloak-standalone-docker-va-kubernetes.md +288 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/03-bai-3-admin-console-va-tao-realm-dau-tien.md +495 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/04-bai-4-quan-ly-users-groups-va-user-profile.md +582 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/05-bai-5-roles-permissions-va-access-control.md +771 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/01-bai-6-openid-connect-clients-cau-hinh-tu-a-den-z.md +1008 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/02-bai-7-saml-clients-va-protocol-mappers.md +681 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/03-bai-8-client-scopes-token-management-va-dpop.md +744 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/04-bai-9-client-policies-va-advanced-client-configuration.md +781 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-mfa-identity-brokering/lessons/01-bai-10-authentication-flows-tuy-chinh-luong-xac-thuc.md +566 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-mfa-identity-brokering/lessons/02-bai-11-multi-factor-authentication-otp-webauthn-va-passkeys.md +587 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-mfa-identity-brokering/lessons/03-bai-12-identity-brokering-va-social-login.md +707 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/01-bai-13-user-federation-ldap-va-active-directory.md +645 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/02-bai-14-organizations-multi-tenancy-va-ciam.md +465 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/03-bai-15-authorization-services-phan-quyen-chi-tiet.md +801 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/04-bai-16-workflows-tu-dong-hoa-quan-tri-voi-iga.md +861 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/05-phan-5-themes-events-security-vault/lessons/01-bai-17-tuy-chinh-giao-dien-keycloak-themes.md +869 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/05-phan-5-themes-events-security-vault/lessons/02-bai-18-event-system-va-audit-logging.md +894 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/05-phan-5-themes-events-security-vault/lessons/03-bai-19-bao-mat-nang-cao-va-vault-integration.md +858 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/01-bai-20-tich-hop-spring-boot-va-quarkus.md +1039 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/02-bai-21-tich-hop-react-angular-va-nodejs.md +1146 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/03-bai-22-api-gateway-nginx-va-microservices.md +1076 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-ha-kubernetes/lessons/01-bai-23-trien-khai-production-va-performance-tuning.md +931 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-ha-kubernetes/lessons/02-bai-24-high-availability-clustering-va-multi-site.md +1225 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-ha-kubernetes/lessons/03-bai-25-kubernetes-operator-monitoring-va-admin-cli.md +1654 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/index.md +677 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/02-bai-1-gioi-thieu-kubernetes-va-container-orchestration.md +466 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/03-bai-2-kien-truc-kubernetes.md +458 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/04-bai-3-cai-dat-moi-truong-kubernetes-2026.md +597 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/05-thuc-hanh-1-thiet-lap-cluster-va-cong-cu.md +656 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/06-bai-5-pods.md +217 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/07-bai-6-replicasets-va-deployments.md +261 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/08-bai-7-services-va-endpointslices.md +195 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/09-bai-8-namespaces.md +212 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/10-thuc-hanh-2-kubernetes-objects-co-ban.md +325 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/11-bai-10-configmaps-va-secrets.md +767 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/12-bai-11-persistent-storage.md +476 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/13-bai-12-statefulsets.md +556 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/14-thuc-hanh-3-configuration-va-storage.md +322 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/15-bai-14-kubernetes-networking-model.md +164 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/16-bai-15-gateway-api-chuan-moi-thay-ingress.md +275 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/17-bai-16-network-policies.md +264 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/18-thuc-hanh-4-networking-voi-cilium-va-gateway-api.md +342 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/19-bai-18-jobs-va-cronjobs.md +428 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/20-bai-19-daemonsets.md +522 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/21-bai-20-autoscaling.md +592 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/22-bai-21-dynamic-resource-allocation-dra.md +224 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/23-thuc-hanh-5-workload-management.md +336 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/24-bai-23-authentication-va-authorization.md +213 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/25-bai-24-validating-admission-policy.md +297 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/26-bai-25-security-best-practices-2026.md +261 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/27-bai-26-security-tools.md +255 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/28-thuc-hanh-6-kubernetes-security.md +323 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/29-bai-28-observability-stack-2026.md +322 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/30-bai-29-prometheus-va-grafana.md +463 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/31-bai-30-loki-tempo-va-distributed-tracing.md +266 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/32-bai-31-debugging-va-troubleshooting.md +259 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/33-thuc-hanh-7-observability-va-logging.md +410 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/34-bai-33-helm-4.md +285 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/35-bai-34-operators-va-custom-resources.md +286 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/36-bai-35-service-mesh-2026.md +212 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/37-bai-36-gitops-voi-argocd-va-flux.md +284 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/38-thuc-hanh-8-helm-operators-gitops.md +336 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/39-bai-38-production-cluster-setup.md +298 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/40-bai-39-infrastructure-migration-2026-cgroup-v2-containerd-2.md +229 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/41-bai-40-node-management.md +213 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/42-bai-41-resource-management.md +266 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/43-bai-42-cluster-api.md +264 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/44-thuc-hanh-9-cluster-management.md +350 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/45-bai-44-managed-kubernetes-services-2026.md +228 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/46-bai-45-cost-optimization.md +233 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/47-bai-46-best-practices-production-2026.md +316 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/48-thuc-hanh-10-cloud-platforms.md +376 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/49-bai-48-kubernetes-cho-ai-ml.md +266 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/index.md +121 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/01-phan-1-co-ban/lessons/02-bai-1-gioi-thieu-va-cai-dat-nginx.md +389 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/01-phan-1-co-ban/lessons/03-bai-2-cau-hinh-co-ban-nginx.md +875 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/01-phan-1-co-ban/lessons/04-bai-3-logging-va-monitoring-nginx.md +635 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/02-phan-2-reverse-proxy-load-balancing/lessons/05-bai-4-reverse-proxy.md +955 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/02-phan-2-reverse-proxy-load-balancing/lessons/06-bai-5-load-balancing.md +1290 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/02-phan-2-reverse-proxy-load-balancing/lessons/07-bai-6-nginx-caching.md +1296 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/08-bai-7-ssl-tls-va-https-trong-nginx.md +1001 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/09-bai-8-performance-tuning-trong-ngi.md +1315 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/10-bai-9-security-trong-nginx.md +1328 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/11-bai-10-rewrite-va-redirects-trong-nginx.md +1070 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/04-phan-4-app-stack-monitoring/lessons/12-bai-11-nginx-voi-application-stack-tr0.md +1228 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/04-phan-4-app-stack-monitoring/lessons/13-bai-12-monitoring-va-logging-trong-nginx.md +1097 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/04-phan-4-app-stack-monitoring/lessons/14-bai-13-high-availability-va-load-balancing-advanced-trong-nginx.md +1285 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/15-bai-14-microservices-va-service-mesh-trong-nginx.md +1405 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/16-bai-15-production-best-practices-va-advanced-topics-trong-nginx.md +1454 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/index.md +282 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/01-bai-1-performance-testing-fundamentals.md +215 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/02-bai-2-sre-practices-slo-sli-sla.md +256 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/03-bai-3-shift-left-performance-testing-ci-cd.md +250 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/04-bai-4-k6-load-testing-framework.md +283 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/05-bai-5-gatling-va-artillery-so-sanh.md +272 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/06-bai-6-api-performance-testing.md +305 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/07-bai-7-database-performance-testing.md +221 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/08-bai-8-cloud-native-performance-testing.md +233 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/09-bai-9-chaos-engineering-load-testing.md +235 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/10-bai-10-observability-ai-performance.md +234 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/11-bai-11-pentest-fundamentals.md +168 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/12-bai-12-ptes-penetration-testing-execution-standard.md +297 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/13-bai-13-owasp-top-10-2025.md +351 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/14-bai-14-reconnaissance-scanning-nmap-amass-nuclei.md +356 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/15-bai-15-web-application-testing-burp-suite-owasp-zap.md +380 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/16-bai-16-exploitation-frameworks-metasploit.md +337 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/17-bai-17-cloud-pentesting-aws-azure-gcp.md +284 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/18-bai-18-container-kubernetes-security-testing.md +340 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/19-bai-19-api-security-testing-owasp-api-top-10.md +349 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/20-bai-20-ai-powered-pentesting-2026.md +391 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/21-bai-21-red-team-adversary-simulation.md +274 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/22-bai-22-blue-team-detection-engineering.md +313 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/23-bai-23-purple-team-collaborative-security.md +250 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/24-bai-24-bug-bounty-methodologies.md +263 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/25-bai-25-compliance-frameworks.md +266 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/26-bai-26-cvss-v4-scoring.md +255 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/27-bai-27-performance-test-report.md +301 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/28-bai-28-pentest-report-technical-executive.md +364 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/29-bai-29-automated-reporting-remediation-tracking.md +382 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/30-bai-30-capstone-project-end-to-end.md +705 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/index.md +474 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/01-phan-1-tong-quan-nen-tang/lessons/02-bai-1-tong-quan-ve-postgresql-high-availability.md +230 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/01-phan-1-tong-quan-nen-tang/lessons/03-bai-2-streaming-replication-trong-postgresql.md +295 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/01-phan-1-tong-quan-nen-tang/lessons/04-bai-3-gioi-thieu-patroni-va-etcd.md +196 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/05-bai-4-chuan-bi-ha-tang.md +496 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/06-bai-5-cai-dat-postgresql.md +326 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/07-bai-6-cai-dat-va-cau-hinh-etcd-cluster.md +404 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/08-bai-7-cai-dat-patroni.md +604 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/09-bai-8-cau-hinh-patroni-chi-tiet.md +547 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/10-bai-9-bootstrap-postgresql-cluster.md +453 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/11-bai-10-quan-ly-replication.md +455 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/12-bai-11-patroni-callbacks.md +792 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/13-bai-12-patroni-rest-api.md +764 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/14-bai-13-automatic-failover.md +507 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/15-bai-14-switchover-co-ke-hoach-planned-switchover.md +685 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/16-bai-15-recovering-failed-nodes.md +566 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/17-bai-16-backup-va-point-in-time-recovery-pitr.md +622 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/18-bai-17-monitoring-patroni-cluster.md +737 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/19-bai-18-performance-tuning.md +625 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/20-bai-19-logging-va-troubleshooting.md +569 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/21-bai-20-security-best-practices.md +481 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/22-bai-21-multi-datacenter-setup.md +509 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/23-bai-22-patroni-voi-kubernetes.md +652 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/24-bai-23-patroni-configuration-management.md +346 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/25-bai-24-upgrade-strategies.md +402 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/26-bai-25-real-world-case-studies.md +483 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/27-bai-26-automation-voi-ansible.md +688 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/28-bai-27-disaster-recovery-drills.md +514 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/29-bai-28-thiet-ke-kien-truc-ha.md +510 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/30-bai-29-deploy-production-ready-cluster.md +722 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/index.md +371 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/01-bai-1-gioi-thieu-django.md +121 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/02-bai-2-models-va-django-orm.md +139 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/03-bai-3-views-urls-va-templates.md +139 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/04-bai-4-class-based-views-va-forms.md +149 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/05-bai-5-drf-serializers-va-views.md +148 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/06-bai-6-viewsets-routers-va-pagination.md +123 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/07-bai-7-advanced-serializers-va-validation.md +137 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/08-bai-8-versioning-throttling-va-api-docs.md +130 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/09-bai-9-authentication-session-token-va-jwt.md +140 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/10-bai-10-permissions-va-authorization.md +120 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/11-bai-11-social-auth-va-oauth2.md +134 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/12-bai-12-security-best-practices.md +126 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-django-admin-customization.md +116 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-django-channels-va-websockets.md +136 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-celery-signals-va-caching.md +145 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-file-storage-email-va-notifications.md +115 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/17-bai-17-testing-trong-django.md +136 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/18-bai-18-performance-optimization.md +127 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/19-bai-19-docker-va-cicd-cho-django.md +159 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/20-bai-20-production-deployment-va-monitoring.md +164 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/index.md +324 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/01-bai-1-gioi-thieu-flutter-va-dart.md +104 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/02-bai-2-dart-language-deep-dive.md +118 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/03-bai-3-widget-tree-va-basic-widgets.md +115 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/04-bai-4-layouts-va-responsive-design.md +118 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/05-bai-5-navigation-va-routing.md +117 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/06-bai-6-state-management-voi-riverpod.md +110 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/07-bai-7-bloc-pattern-va-cubit.md +151 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/08-bai-8-forms-validation-va-theming.md +167 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/09-bai-9-http-va-rest-api-integration.md +172 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/10-bai-10-local-storage-va-offline-first.md +131 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/11-bai-11-firebase-integration.md +118 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/12-bai-12-authentication-va-authorization.md +155 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/13-bai-13-animations-va-motion.md +203 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/14-bai-14-custom-painting-va-advanced-widgets.md +177 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/15-bai-15-platform-channels-va-native-integration.md +139 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/16-bai-16-push-notifications-va-background-tasks.md +174 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-va-patterns/lessons/17-bai-17-clean-architecture-cho-flutter.md +159 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-va-patterns/lessons/18-bai-18-code-generation-va-freezed.md +130 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/19-bai-19-testing-trong-flutter.md +173 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/20-bai-20-performance-va-debugging.md +116 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/21-bai-21-cicd-va-app-signing.md +173 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/22-bai-22-publish-len-app-store-va-google-play.md +134 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/index.md +350 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/01-bai-1-gioi-thieu-go-ngon-ngu-cua-cloud-native.md +397 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/02-bai-2-variables-types-va-control-flow.md +647 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/03-bai-3-functions-interfaces-va-error-handling.md +611 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/04-bai-4-generics-packages-va-modules.md +586 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/05-bai-5-goroutines-va-channels.md +536 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/06-bai-6-context-sync-va-concurrency-patterns.md +579 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/07-bai-7-http-server-va-json-handling.md +548 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/08-bai-8-gin-framework-va-rest-api.md +547 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/09-bai-9-gorm-va-database-integration.md +467 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/10-bai-10-migrations-va-repository-pattern.md +519 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/11-bai-11-authentication-jwt-va-oauth2.md +497 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/12-bai-12-authorization-security-va-middleware.md +366 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-websockets-va-real-time.md +398 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-grpc-va-protocol-buffers.md +524 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-message-queues-va-event-driven.md +506 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-caching-file-upload-va-performance.md +393 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/17-bai-17-microservices-architecture-voi-go.md +365 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/18-bai-18-testing-trong-go.md +442 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/19-bai-19-docker-cicd-va-devops.md +391 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/20-bai-20-production-deployment-va-observability.md +428 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/index.md +323 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/01-bai-1-gioi-thieu-laravel.md +110 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/02-bai-2-routing-controllers-va-middleware.md +133 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/03-bai-3-blade-templates-va-frontend.md +119 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/04-bai-4-eloquent-orm-va-relationships.md +133 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/05-bai-5-migrations-seeding-va-query-builder.md +127 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/06-bai-6-validation-va-form-requests.md +118 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/07-bai-7-api-resources-va-response.md +116 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/08-bai-8-file-storage-va-media.md +111 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/09-bai-9-authentication-sanctum-va-fortify.md +110 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/10-bai-10-authorization-gates-va-policies.md +120 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/11-bai-11-oauth2-passport-va-socialite.md +111 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/12-bai-12-security-best-practices.md +99 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-queues-va-jobs.md +120 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-events-listeners-va-broadcasting.md +109 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-notifications-mail-va-scheduler.md +129 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-caching-sessions-va-performance.md +103 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/05-phan-5-modern-full-stack/lessons/17-bai-17-livewire-full-stack-components.md +130 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/05-phan-5-modern-full-stack/lessons/18-bai-18-inertiajs-va-vue-react.md +136 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/19-bai-19-testing-trong-laravel.md +124 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/20-bai-20-clean-architecture-va-packages.md +126 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/21-bai-21-docker-va-cicd.md +138 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/22-bai-22-production-deployment-va-monitoring.md +123 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/index.md +354 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/01-bai-1-gioi-thieu-nestjs-tai-sao-chon-nestjs.md +162 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/02-bai-2-typescript-essentials-cho-nestjs.md +298 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/03-bai-3-cai-dat-va-khoi-tao-nestjs-project.md +336 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/04-bai-4-controllers-va-routing-trong-nestjs.md +310 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/05-bai-5-providers-va-dependency-injection.md +279 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/06-bai-6-modules-to-chuc-code-theo-feature.md +258 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/07-bai-7-typeorm-va-prisma-ket-noi-database.md +381 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/08-bai-8-validation-pipes-va-exception-filters.md +307 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/09-bai-9-authentication-voi-passport-va-jwt.md +343 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/10-bai-10-guards-va-authorization-rbac.md +252 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/11-bai-11-security-best-practices.md +207 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/12-bai-12-session-cookies-va-oauth2.md +244 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-interceptors-middleware-va-request-lifecycle.md +220 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-websockets-va-real-time-communication.md +263 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-graphql-voi-nestjs.md +262 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-file-upload-caching-va-task-scheduling.md +302 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/17-bai-17-nestjs-microservices.md +228 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/18-bai-18-testing-trong-nestjs.md +310 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/19-bai-19-dockerize-va-ci-cd-cho-nestjs.md +271 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/20-bai-20-production-deployment-va-monitoring.md +352 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/index.md +323 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/01-bai-1-nodejs-architecture-deep-dive.md +117 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/02-bai-2-event-loop-va-async-patterns.md +148 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/03-bai-3-module-system-va-package-management.md +129 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/04-bai-4-typescript-va-modern-javascript.md +147 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/05-bai-5-file-system-va-path.md +131 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/06-bai-6-streams-va-buffers.md +153 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/07-bai-7-http-https-va-http2.md +147 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/08-bai-8-crypto-os-va-process.md +143 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/09-bai-9-worker-threads-va-cpu-intensive.md +131 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/10-bai-10-cluster-module-va-load-balancing.md +135 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/11-bai-11-tcp-udp-va-websockets.md +160 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/12-bai-12-events-timers-va-diagnostics.md +151 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/13-bai-13-xay-dung-http-framework-tu-scratch.md +185 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/14-bai-14-database-drivers-va-connection-pooling.md +153 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/15-bai-15-caching-queues-va-background-jobs.md +146 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/16-bai-16-native-addons-va-napi.md +139 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/17-bai-17-testing-nodejs-applications.md +173 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/18-bai-18-performance-profiling-va-optimization.md +122 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/19-bai-19-docker-va-cicd.md +169 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/20-bai-20-production-monitoring-va-scaling.md +184 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/index.md +321 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/01-bai-1-gioi-thieu-fastapi-framework-python-hien-dai-nhat.md +222 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/02-bai-2-python-essentials-cho-fastapi.md +398 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/03-bai-3-cai-dat-va-khoi-tao-fastapi-project.md +412 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/04-bai-4-path-operations-request-va-response.md +485 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/05-bai-5-pydantic-v2-data-validation-va-serialization.md +466 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/06-bai-6-sqlalchemy-2-va-async-database.md +412 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/07-bai-7-alembic-migrations-va-database-seeding.md +417 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/08-bai-8-crud-operations-va-repository-pattern.md +487 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/09-bai-9-authentication-voi-oauth2-va-jwt.md +415 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/10-bai-10-authorization-rbac-va-permissions.md +313 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/11-bai-11-security-best-practices.md +255 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/12-bai-12-social-login-va-oauth2-providers.md +338 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-middleware-events-va-lifespan.md +239 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-websockets-va-real-time-communication.md +318 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-background-tasks-celery-va-task-queues.md +331 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-file-upload-caching-va-async-deep-dive.md +358 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/17-bai-17-clean-architecture-va-project-structure.md +349 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/18-bai-18-testing-trong-fastapi.md +488 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/19-bai-19-dockerize-va-cicd-cho-fastapi.md +464 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/20-bai-20-production-deployment-va-monitoring.md +517 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/index.md +308 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/01-bai-1-quarkus-la-gi.md +377 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/02-bai-2-tao-quarkus-project.md +376 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/03-bai-3-quarkus-rest.md +349 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/04-bai-4-postgresql-panache.md +422 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/05-bai-5-validation-error-handling.md +758 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/06-bai-6-ddd-database-per-service.md +631 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/07-bai-7-product-service.md +469 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/08-bai-8-order-service.md +443 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/09-bai-9-payment-notification-service.md +542 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/03-phan-3-security-keycloak/lessons/10-bai-10-keycloak-setup.md +571 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/03-phan-3-security-keycloak/lessons/11-bai-11-oidc-authentication.md +592 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/03-phan-3-security-keycloak/lessons/12-bai-12-rbac-admin-client.md +1900 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/04-phan-4-inter-service-communication/lessons/13-bai-13-rest-client.md +529 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/04-phan-4-inter-service-communication/lessons/14-bai-14-grpc.md +394 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/04-phan-4-inter-service-communication/lessons/15-bai-15-kafka-event-driven.md +402 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/05-phan-5-resilience-observability/lessons/16-bai-16-fault-tolerance.md +472 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/05-phan-5-resilience-observability/lessons/17-bai-17-opentelemetry.md +348 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/05-phan-5-resilience-observability/lessons/18-bai-18-caching-health-gateway.md +387 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/06-phan-6-testing/lessons/19-bai-19-quarkustest-testcontainers.md +414 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/06-phan-6-testing/lessons/20-bai-20-contract-testing-pact.md +678 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/07-phan-7-deployment-production/lessons/21-bai-21-graalvm-native-container.md +419 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/07-phan-7-deployment-production/lessons/22-bai-22-kubernetes-cicd.md +603 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/index.md +381 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/01-bai-1-gioi-thieu-react.md +169 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/02-bai-2-components-props-va-typescript.md +234 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/03-bai-3-hooks-deep-dive.md +318 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/04-bai-4-event-handling-forms-va-conditional-rendering.md +243 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-react-advanced-va-state-management/lessons/05-bai-5-context-api-va-state-management.md +230 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-react-advanced-va-state-management/lessons/06-bai-6-react-patterns-va-performance.md +164 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-react-advanced-va-state-management/lessons/07-bai-7-styling-va-ui-components.md +200 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/08-bai-8-nextjs-va-app-router.md +204 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/09-bai-9-server-components-va-client-components.md +161 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/10-bai-10-data-fetching-va-caching.md +169 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/11-bai-11-server-actions-va-mutations.md +196 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/12-bai-12-authentication-voi-nextauthjs.md +203 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/13-bai-13-middleware-api-routes-va-route-handlers.md +214 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/14-bai-14-database-integration-va-prisma.md +226 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/15-bai-15-internationalization-va-seo.md +203 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-full-stack-features/lessons/16-bai-16-file-upload-va-image-optimization.md +195 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-full-stack-features/lessons/17-bai-17-real-time-va-websockets.md +234 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-full-stack-features/lessons/18-bai-18-email-payment-va-third-party.md +201 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/19-bai-19-testing-react-va-nextjs.md +182 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/20-bai-20-performance-optimization.md +168 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/21-bai-21-docker-va-cicd.md +197 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/22-bai-22-production-best-practices-va-monitoring.md +236 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/index.md +348 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/01-bai-1-gioi-thieu-rust.md +104 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/02-bai-2-variables-types-va-control-flow.md +141 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/03-bai-3-ownership-borrowing-va-lifetimes.md +141 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/04-bai-4-structs-enums-va-pattern-matching.md +191 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/05-bai-5-traits-va-generics.md +154 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/06-bai-6-closures-iterators-va-collections.md +126 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/07-bai-7-error-handling-va-modules.md +154 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/08-bai-8-smart-pointers-va-concurrency.md +153 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/09-bai-9-async-rust-va-tokio.md +139 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/10-bai-10-axum-framework-va-rest-api.md +154 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/11-bai-11-sqlx-va-database-integration.md +140 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/12-bai-12-authentication-va-authorization.md +164 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/13-bai-13-websockets-va-real-time.md +147 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/14-bai-14-grpc-voi-tonic.md +134 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/15-bai-15-message-queues-va-background-jobs.md +147 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/16-bai-16-caching-cli-tools-va-macros.md +174 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/05-phan-5-webassembly-va-systems/lessons/17-bai-17-webassembly-voi-rust.md +156 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/05-phan-5-webassembly-va-systems/lessons/18-bai-18-ffi-va-unsafe-rust.md +177 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/19-bai-19-testing-va-benchmarking.md +142 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/20-bai-20-docker-va-cicd-cho-rust.md +153 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/21-bai-21-observability-va-monitoring.md +141 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/22-bai-22-production-deployment-va-performance-tuning.md +157 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/index.md +350 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/02-bai-1-spring-boot-la-gi.md +263 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/03-bai-2-cai-dat-moi-truong-va-khoi-tao-project.md +472 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/04-bai-3-auto-configuration-ioc-container.md +442 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/05-bai-4-dependency-injection-bean-lifecycle.md +430 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/02-bai-5-rest-api-foundations.md +387 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/03-bai-6-dto-validation-exception-handling.md +412 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/04-bai-7-spring-data-jpa-entity-repository.md +399 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/05-bai-8-quan-he-entity-pagination-specification.md +415 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/02-bai-9-spring-security-fundamentals.md +313 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/03-bai-10-jwt-authentication.md +400 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/04-bai-11-oauth2-openid-connect.md +306 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/05-bai-12-method-security-cors-csrf.md +261 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/02-bai-13-transaction-management-caching.md +281 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/03-bai-14-async-scheduling-events.md +301 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/04-bai-15-file-upload-email-websocket.md +312 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/05-bai-16-openapi-hateoas.md +271 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/02-bai-17-unit-testing-junit5-mockito.md +275 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/03-bai-18-integration-testing-testcontainers.md +297 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/04-bai-19-api-testing-mockmvc-webtestclient.md +258 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/05-bai-20-actuator-micrometer-observability.md +338 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/02-bai-21-docker-containerization.md +240 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/03-bai-22-microservices-service-discovery-api-gateway.md +317 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/04-bai-23-kafka-rabbitmq-event-driven.md +325 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/05-bai-24-cicd-cloud-deployment-production.md +416 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/index.md +322 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/01-bai-1-vibe-coding-la-gi-ky-nguyen-moi-cua-lap-trinh-voi-ai.md +251 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/02-bai-2-cai-dat-va-cau-hinh-github-copilot-trong-vs-code.md +321 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/03-bai-3-inline-suggestions-va-next-edit-suggestions.md +290 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/04-bai-4-inline-chat-va-smart-actions.md +269 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/02-phan-2-agent-mode/lessons/05-bai-5-agent-mode-de-ai-tu-viet-code-cho-ban.md +294 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/02-phan-2-agent-mode/lessons/06-bai-6-plan-agent-lap-ke-hoach-truoc-khi-code.md +244 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/02-phan-2-agent-mode/lessons/07-bai-7-cloud-agent-va-copilot-cli.md +273 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/03-phan-3-prompt-engineering-cho-code/lessons/08-bai-8-nghe-thuat-viet-prompt-cho-code.md +307 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/03-phan-3-prompt-engineering-cho-code/lessons/09-bai-9-context-management-cung-cap-ngu-canh-cho-ai.md +207 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/03-phan-3-prompt-engineering-cho-code/lessons/10-bai-10-prompt-patterns-nang-cao.md +270 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/04-phan-4-customize-va-extend-copilot/lessons/11-bai-11-custom-instructions-day-ai-theo-coding-style-cua-ban.md +223 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/04-phan-4-customize-va-extend-copilot/lessons/12-bai-12-custom-agents-va-agent-skills.md +312 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/04-phan-4-customize-va-extend-copilot/lessons/13-bai-13-mcp-servers-ket-noi-ai-voi-the-gioi-ben-ngoai.md +279 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/05-phan-5-vibe-coding-thuc-chien/lessons/14-bai-14-vibe-coding-full-stack-app-phan-1-backend.md +500 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/05-phan-5-vibe-coding-thuc-chien/lessons/15-bai-15-vibe-coding-full-stack-app-phan-2-frontend.md +429 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/05-phan-5-vibe-coding-thuc-chien/lessons/16-bai-16-vibe-coding-cho-mobile-va-cross-platform.md +366 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/17-bai-17-code-quality-va-review-vibe-coding-co-trach-nhiem.md +301 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/18-bai-18-security-trong-vibe-coding.md +371 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/19-bai-19-technical-debt-va-maintainability.md +301 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/20-bai-20-vibe-coding-trong-team-va-production.md +435 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/index.md +322 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/01-bai-1-gioi-thieu-vuejs.md +154 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/02-bai-2-reactivity-system-va-composition-api.md +195 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/03-bai-3-components-props-va-events.md +209 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/04-bai-4-directives-rendering-va-template-refs.md +182 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/05-bai-5-vue-router-deep-dive.md +164 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/06-bai-6-state-management-voi-pinia.md +177 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/07-bai-7-composables-va-reusable-logic.md +186 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/08-bai-8-forms-validation-va-styling.md +178 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/09-bai-9-nuxt-3-va-file-based-routing.md +187 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/10-bai-10-data-fetching-va-ssr.md +149 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/11-bai-11-nitro-server-engine-va-api-routes.md +189 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/12-bai-12-middleware-plugins-va-modules.md +178 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/13-bai-13-authentication-va-authorization.md +173 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/14-bai-14-database-va-orm-trong-nuxt.md +173 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/15-bai-15-file-upload-images-va-seo.md +158 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/16-bai-16-real-time-websockets-va-i18n.md +176 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/05-phan-5-advanced-patterns/lessons/17-bai-17-animations-va-transitions.md +198 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/05-phan-5-advanced-patterns/lessons/18-bai-18-advanced-patterns-va-custom-module.md +184 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/19-bai-19-testing-vue-va-nuxt.md +207 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/20-bai-20-performance-optimization.md +206 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/21-bai-21-deployment-va-hosting.md +206 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/22-bai-22-production-monitoring-va-best-practices.md +244 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/index.md +347 -0
- package/content/showcase/autox.md +141 -0
- package/content/showcase/x-lms.md +118 -0
- package/content/showcase/x-postgres-backup.md +96 -0
- package/content/showcase/xclaw-app.md +66 -0
- package/content/showcase/xclaw.md +80 -0
- package/content/showcase/xdev-asia.md +102 -0
- package/content/showcase/xdev-reader.md +68 -0
- package/data/authors.json +8 -0
- package/data/categories.json +98 -0
- package/data/github-repos.json +44 -0
- package/data/reviews.json +1 -0
- package/data/settings.json +23 -0
- package/data/tags.json +122 -0
- package/dist/content-loader.d.ts +56 -0
- package/dist/content-loader.d.ts.map +1 -0
- package/dist/content-loader.js +331 -0
- package/dist/content-loader.js.map +1 -0
- package/dist/data/hipaa-safeguards.d.ts +28 -0
- package/dist/data/hipaa-safeguards.d.ts.map +1 -0
- package/dist/data/hipaa-safeguards.js +222 -0
- package/dist/data/hipaa-safeguards.js.map +1 -0
- package/dist/data/phi-classifier.d.ts +36 -0
- package/dist/data/phi-classifier.d.ts.map +1 -0
- package/dist/data/phi-classifier.js +115 -0
- package/dist/data/phi-classifier.js.map +1 -0
- package/dist/data/security-configs.d.ts +14 -0
- package/dist/data/security-configs.d.ts.map +1 -0
- package/dist/data/security-configs.js +507 -0
- package/dist/data/security-configs.js.map +1 -0
- package/dist/data/threat-patterns.d.ts +44 -0
- package/dist/data/threat-patterns.d.ts.map +1 -0
- package/dist/data/threat-patterns.js +177 -0
- package/dist/data/threat-patterns.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/dist/prompts/index.d.ts +3 -0
- package/dist/prompts/index.d.ts.map +1 -0
- package/dist/prompts/index.js +228 -0
- package/dist/prompts/index.js.map +1 -0
- package/dist/resources/index.d.ts +3 -0
- package/dist/resources/index.d.ts.map +1 -0
- package/dist/resources/index.js +218 -0
- package/dist/resources/index.js.map +1 -0
- package/dist/tools/index.d.ts +3 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +684 -0
- package/dist/tools/index.js.map +1 -0
- package/package.json +58 -0
|
@@ -0,0 +1,1454 @@
|
|
|
1
|
+
---
|
|
2
|
+
id: 019c9617-fca6-7277-8b61-c480821e8bcb
|
|
3
|
+
title: 'Bài 15: Production Best Practices và Advanced Topics trong NGINX'
|
|
4
|
+
slug: bai-15-production-best-practices-va-advanced-topics-trong-nginx
|
|
5
|
+
description: >-
|
|
6
|
+
Bài học tổng hợp về Production Best Practices - configuration management,
|
|
7
|
+
deployment strategies, troubleshooting guide, performance optimization,
|
|
8
|
+
security hardening, cost optimization, disaster recovery, compliance (PCI-DSS,
|
|
9
|
+
HIPAA, GDPR), multi-cloud strategies và production readiness checklist.
|
|
10
|
+
duration_minutes: 235
|
|
11
|
+
is_free: true
|
|
12
|
+
video_url: null
|
|
13
|
+
sort_order: 15
|
|
14
|
+
section_title: "Phần 5: Production & Advanced"
|
|
15
|
+
course:
|
|
16
|
+
id: 019c9617-fc27-73c5-b664-a1902ec9ac00
|
|
17
|
+
title: Nginx từ Cơ bản đến Nâng cao
|
|
18
|
+
slug: nginx-tu-co-ban-den-nang-cao
|
|
19
|
+
---
|
|
20
|
+
<h2 id="1-configuration-management"><strong>1. Configuration Management</strong></h2><h3 id="11-configuration-structure"><strong>1.1. Configuration Structure</strong></h3><pre><code class="language-bash">/etc/nginx/
|
|
21
|
+
├── nginx.conf # Main configuration
|
|
22
|
+
├── mime.types # MIME types
|
|
23
|
+
├── fastcgi_params # FastCGI parameters
|
|
24
|
+
├── proxy_params # Proxy parameters
|
|
25
|
+
├── snippets/ # Reusable configuration snippets
|
|
26
|
+
│ ├── ssl-params.conf
|
|
27
|
+
│ ├── security-headers.conf
|
|
28
|
+
│ ├── proxy-common.conf
|
|
29
|
+
│ └── fastcgi-common.conf
|
|
30
|
+
├── conf.d/ # Global configurations
|
|
31
|
+
│ ├── upstreams/
|
|
32
|
+
│ │ ├── api-services.conf
|
|
33
|
+
│ │ ├── web-services.conf
|
|
34
|
+
│ │ └── db-services.conf
|
|
35
|
+
│ ├── maps/
|
|
36
|
+
│ │ ├── geo-routing.conf
|
|
37
|
+
│ │ └── device-detection.conf
|
|
38
|
+
│ └── cache/
|
|
39
|
+
│ └── cache-zones.conf
|
|
40
|
+
├── sites-available/ # Site configurations
|
|
41
|
+
│ ├── example.com.conf
|
|
42
|
+
│ ├── api.example.com.conf
|
|
43
|
+
│ └── admin.example.com.conf
|
|
44
|
+
├── sites-enabled/ # Enabled sites (symlinks)
|
|
45
|
+
│ ├── example.com.conf -> ../sites-available/example.com.conf
|
|
46
|
+
│ └── api.example.com.conf -> ../sites-available/api.example.com.conf
|
|
47
|
+
├── ssl/ # SSL certificates
|
|
48
|
+
│ ├── certs/
|
|
49
|
+
│ ├── private/
|
|
50
|
+
│ └── dhparam.pem
|
|
51
|
+
├── includes/ # Include files
|
|
52
|
+
│ ├── rate-limits.conf
|
|
53
|
+
│ ├── blacklist.conf
|
|
54
|
+
│ └── whitelist.conf
|
|
55
|
+
└── modules-enabled/ # Dynamic modules
|
|
56
|
+
└── ngx_http_geoip_module.so
|
|
57
|
+
</code></pre><h3 id="12-modular-configuration"><strong>1.2. Modular Configuration</strong></h3><p><strong>Main configuration:</strong></p><pre><code class="language-nginx"># /etc/nginx/nginx.conf
|
|
58
|
+
user nginx;
|
|
59
|
+
worker_processes auto;
|
|
60
|
+
worker_rlimit_nofile 65535;
|
|
61
|
+
|
|
62
|
+
error_log /var/log/nginx/error.log warn;
|
|
63
|
+
pid /var/run/nginx.pid;
|
|
64
|
+
|
|
65
|
+
# Load dynamic modules
|
|
66
|
+
include /etc/nginx/modules-enabled/*.conf;
|
|
67
|
+
|
|
68
|
+
events {
|
|
69
|
+
worker_connections 4096;
|
|
70
|
+
use epoll;
|
|
71
|
+
multi_accept on;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
http {
|
|
75
|
+
include /etc/nginx/mime.types;
|
|
76
|
+
default_type application/octet-stream;
|
|
77
|
+
|
|
78
|
+
# Logging
|
|
79
|
+
include /etc/nginx/conf.d/logging.conf;
|
|
80
|
+
|
|
81
|
+
# Performance
|
|
82
|
+
include /etc/nginx/conf.d/performance.conf;
|
|
83
|
+
|
|
84
|
+
# Security
|
|
85
|
+
include /etc/nginx/conf.d/security.conf;
|
|
86
|
+
|
|
87
|
+
# Rate limiting
|
|
88
|
+
include /etc/nginx/conf.d/rate-limiting.conf;
|
|
89
|
+
|
|
90
|
+
# Upstreams
|
|
91
|
+
include /etc/nginx/conf.d/upstreams/*.conf;
|
|
92
|
+
|
|
93
|
+
# Cache zones
|
|
94
|
+
include /etc/nginx/conf.d/cache/*.conf;
|
|
95
|
+
|
|
96
|
+
# Maps
|
|
97
|
+
include /etc/nginx/conf.d/maps/*.conf;
|
|
98
|
+
|
|
99
|
+
# Sites
|
|
100
|
+
include /etc/nginx/sites-enabled/*;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
# Stream (TCP/UDP proxy)
|
|
104
|
+
stream {
|
|
105
|
+
include /etc/nginx/conf.d/stream/*.conf;
|
|
106
|
+
}
|
|
107
|
+
</code></pre><p><strong>Reusable snippets:</strong></p><pre><code class="language-nginx"># /etc/nginx/snippets/ssl-params.conf
|
|
108
|
+
ssl_protocols TLSv1.2 TLSv1.3;
|
|
109
|
+
ssl_prefer_server_ciphers off;
|
|
110
|
+
ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384;
|
|
111
|
+
ssl_session_cache shared:SSL:10m;
|
|
112
|
+
ssl_session_timeout 10m;
|
|
113
|
+
ssl_session_tickets off;
|
|
114
|
+
ssl_stapling on;
|
|
115
|
+
ssl_stapling_verify on;
|
|
116
|
+
</code></pre><pre><code class="language-nginx"># /etc/nginx/snippets/security-headers.conf
|
|
117
|
+
add_header X-Frame-Options "SAMEORIGIN" always;
|
|
118
|
+
add_header X-Content-Type-Options "nosniff" always;
|
|
119
|
+
add_header X-XSS-Protection "1; mode=block" always;
|
|
120
|
+
add_header Referrer-Policy "strict-origin-when-cross-origin" always;
|
|
121
|
+
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always;
|
|
122
|
+
add_header Content-Security-Policy "default-src 'self'; script-src 'self' 'unsafe-inline'; style-src 'self' 'unsafe-inline';" always;
|
|
123
|
+
add_header Permissions-Policy "geolocation=(), microphone=(), camera=()" always;
|
|
124
|
+
</code></pre><pre><code class="language-nginx"># /etc/nginx/snippets/proxy-common.conf
|
|
125
|
+
proxy_http_version 1.1;
|
|
126
|
+
proxy_set_header Connection "";
|
|
127
|
+
proxy_set_header Host $host;
|
|
128
|
+
proxy_set_header X-Real-IP $remote_addr;
|
|
129
|
+
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
130
|
+
proxy_set_header X-Forwarded-Proto $scheme;
|
|
131
|
+
proxy_set_header X-Request-ID $request_id;
|
|
132
|
+
|
|
133
|
+
proxy_connect_timeout 5s;
|
|
134
|
+
proxy_send_timeout 10s;
|
|
135
|
+
proxy_read_timeout 30s;
|
|
136
|
+
|
|
137
|
+
proxy_buffering on;
|
|
138
|
+
proxy_buffer_size 8k;
|
|
139
|
+
proxy_buffers 16 8k;
|
|
140
|
+
proxy_busy_buffers_size 16k;
|
|
141
|
+
</code></pre><h3 id="13-version-control"><strong>1.3. Version Control</strong></h3><pre><code class="language-bash"># Initialize Git repository
|
|
142
|
+
cd /etc/nginx
|
|
143
|
+
git init
|
|
144
|
+
|
|
145
|
+
# Add .gitignore
|
|
146
|
+
cat > .gitignore << EOF
|
|
147
|
+
*.log
|
|
148
|
+
ssl/private/*.key
|
|
149
|
+
ssl/private/*.pem
|
|
150
|
+
.htpasswd
|
|
151
|
+
*.tmp
|
|
152
|
+
*.bak
|
|
153
|
+
EOF
|
|
154
|
+
|
|
155
|
+
# Add files
|
|
156
|
+
git add .
|
|
157
|
+
git commit -m "Initial Nginx configuration"
|
|
158
|
+
|
|
159
|
+
# Create backup branch
|
|
160
|
+
git branch backup-$(date +%Y%m%d)
|
|
161
|
+
|
|
162
|
+
# Before making changes
|
|
163
|
+
git checkout -b feature/new-rate-limits
|
|
164
|
+
|
|
165
|
+
# After testing
|
|
166
|
+
git checkout main
|
|
167
|
+
git merge feature/new-rate-limits
|
|
168
|
+
git tag -a v1.0.0 -m "Production release 1.0.0"
|
|
169
|
+
</code></pre><p><strong>Automated backup script:</strong></p><pre><code class="language-bash">#!/bin/bash
|
|
170
|
+
# /usr/local/bin/nginx-config-backup.sh
|
|
171
|
+
|
|
172
|
+
BACKUP_DIR="/backup/nginx"
|
|
173
|
+
DATE=$(date +%Y%m%d-%H%M%S)
|
|
174
|
+
REMOTE_BACKUP="backup-server:/backups/nginx"
|
|
175
|
+
|
|
176
|
+
# Create backup
|
|
177
|
+
mkdir -p $BACKUP_DIR
|
|
178
|
+
|
|
179
|
+
# Backup configuration
|
|
180
|
+
tar -czf $BACKUP_DIR/nginx-config-$DATE.tar.gz \
|
|
181
|
+
--exclude='*.log' \
|
|
182
|
+
--exclude='ssl/private' \
|
|
183
|
+
/etc/nginx
|
|
184
|
+
|
|
185
|
+
# Backup to Git
|
|
186
|
+
cd /etc/nginx
|
|
187
|
+
git add -A
|
|
188
|
+
git commit -m "Automated backup $DATE" || true
|
|
189
|
+
|
|
190
|
+
# Sync to remote
|
|
191
|
+
rsync -avz $BACKUP_DIR/ $REMOTE_BACKUP/
|
|
192
|
+
|
|
193
|
+
# Keep only last 30 days
|
|
194
|
+
find $BACKUP_DIR -name "*.tar.gz" -mtime +30 -delete
|
|
195
|
+
|
|
196
|
+
echo "Backup completed: $DATE"
|
|
197
|
+
</code></pre><h3 id="14-configuration-testing"><strong>1.4. Configuration Testing</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
198
|
+
# /usr/local/bin/nginx-config-test.sh
|
|
199
|
+
|
|
200
|
+
echo "Testing Nginx configuration..."
|
|
201
|
+
|
|
202
|
+
# Test syntax
|
|
203
|
+
if nginx -t 2>&1 | tee /tmp/nginx-test.log; then
|
|
204
|
+
echo "✓ Configuration syntax is valid"
|
|
205
|
+
else
|
|
206
|
+
echo "✗ Configuration syntax error"
|
|
207
|
+
cat /tmp/nginx-test.log
|
|
208
|
+
exit 1
|
|
209
|
+
fi
|
|
210
|
+
|
|
211
|
+
# Test specific configurations
|
|
212
|
+
echo ""
|
|
213
|
+
echo "Running additional tests..."
|
|
214
|
+
|
|
215
|
+
# Check for duplicate server names
|
|
216
|
+
DUPLICATES=$(nginx -T 2>/dev/null | grep "server_name" | sort | uniq -d)
|
|
217
|
+
if [ ! -z "$DUPLICATES" ]; then
|
|
218
|
+
echo "✗ Warning: Duplicate server names found:"
|
|
219
|
+
echo "$DUPLICATES"
|
|
220
|
+
fi
|
|
221
|
+
|
|
222
|
+
# Check for weak SSL protocols
|
|
223
|
+
if nginx -T 2>/dev/null | grep -q "ssl_protocols.*TLSv1\s"; then
|
|
224
|
+
echo "✗ Warning: Weak SSL protocols (TLSv1) detected"
|
|
225
|
+
fi
|
|
226
|
+
|
|
227
|
+
# Check if rate limiting is configured
|
|
228
|
+
if nginx -T 2>/dev/null | grep -q "limit_req_zone"; then
|
|
229
|
+
echo "✓ Rate limiting configured"
|
|
230
|
+
else
|
|
231
|
+
echo "⚠ Warning: No rate limiting configured"
|
|
232
|
+
fi
|
|
233
|
+
|
|
234
|
+
# Check if security headers are present
|
|
235
|
+
if nginx -T 2>/dev/null | grep -q "X-Frame-Options"; then
|
|
236
|
+
echo "✓ Security headers configured"
|
|
237
|
+
else
|
|
238
|
+
echo "⚠ Warning: Security headers not configured"
|
|
239
|
+
fi
|
|
240
|
+
|
|
241
|
+
echo ""
|
|
242
|
+
echo "Configuration test complete"
|
|
243
|
+
</code></pre><hr><h2 id="2-deployment-strategies"><strong>2. Deployment Strategies</strong></h2><h3 id="21-zero-downtime-deployment"><strong>2.1. Zero-Downtime Deployment</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
244
|
+
# /usr/local/bin/nginx-deploy.sh
|
|
245
|
+
|
|
246
|
+
set -e
|
|
247
|
+
|
|
248
|
+
BACKUP_DIR="/backup/nginx/deployments"
|
|
249
|
+
DATE=$(date +%Y%m%d-%H%M%S)
|
|
250
|
+
|
|
251
|
+
echo "Starting Nginx deployment - $DATE"
|
|
252
|
+
|
|
253
|
+
# Step 1: Backup current configuration
|
|
254
|
+
echo "Step 1: Backing up current configuration..."
|
|
255
|
+
mkdir -p $BACKUP_DIR
|
|
256
|
+
cp -r /etc/nginx $BACKUP_DIR/nginx-$DATE
|
|
257
|
+
|
|
258
|
+
# Step 2: Copy new configuration
|
|
259
|
+
echo "Step 2: Deploying new configuration..."
|
|
260
|
+
# rsync -av /path/to/new/config/ /etc/nginx/
|
|
261
|
+
|
|
262
|
+
# Step 3: Test configuration
|
|
263
|
+
echo "Step 3: Testing configuration..."
|
|
264
|
+
if ! nginx -t; then
|
|
265
|
+
echo "✗ Configuration test failed. Rolling back..."
|
|
266
|
+
rm -rf /etc/nginx
|
|
267
|
+
cp -r $BACKUP_DIR/nginx-$DATE /etc/nginx
|
|
268
|
+
exit 1
|
|
269
|
+
fi
|
|
270
|
+
|
|
271
|
+
# Step 4: Reload Nginx (zero downtime)
|
|
272
|
+
echo "Step 4: Reloading Nginx..."
|
|
273
|
+
nginx -s reload
|
|
274
|
+
|
|
275
|
+
# Step 5: Health check
|
|
276
|
+
echo "Step 5: Running health checks..."
|
|
277
|
+
sleep 2
|
|
278
|
+
|
|
279
|
+
for i in {1..5}; do
|
|
280
|
+
if curl -sf http://localhost/health > /dev/null; then
|
|
281
|
+
echo "✓ Health check passed (attempt $i)"
|
|
282
|
+
break
|
|
283
|
+
else
|
|
284
|
+
if [ $i -eq 5 ]; then
|
|
285
|
+
echo "✗ Health checks failed. Rolling back..."
|
|
286
|
+
rm -rf /etc/nginx
|
|
287
|
+
cp -r $BACKUP_DIR/nginx-$DATE /etc/nginx
|
|
288
|
+
nginx -s reload
|
|
289
|
+
exit 1
|
|
290
|
+
fi
|
|
291
|
+
sleep 2
|
|
292
|
+
fi
|
|
293
|
+
done
|
|
294
|
+
|
|
295
|
+
echo "✓ Deployment successful - $DATE"
|
|
296
|
+
|
|
297
|
+
# Cleanup old backups (keep last 10)
|
|
298
|
+
ls -t $BACKUP_DIR | tail -n +11 | xargs -I {} rm -rf $BACKUP_DIR/{}
|
|
299
|
+
</code></pre><h3 id="22-blue-green-deployment-script"><strong>2.2. Blue-Green Deployment Script</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
300
|
+
# /usr/local/bin/nginx-bluegreen.sh
|
|
301
|
+
|
|
302
|
+
CURRENT_ENV=$(cat /etc/nginx/conf.d/active-env.conf | grep -oP 'upstream \K\w+')
|
|
303
|
+
HEALTH_ENDPOINT="http://localhost/health"
|
|
304
|
+
|
|
305
|
+
if [ "$CURRENT_ENV" == "blue" ]; then
|
|
306
|
+
NEW_ENV="green"
|
|
307
|
+
else
|
|
308
|
+
NEW_ENV="blue"
|
|
309
|
+
fi
|
|
310
|
+
|
|
311
|
+
echo "Current environment: $CURRENT_ENV"
|
|
312
|
+
echo "Switching to: $NEW_ENV"
|
|
313
|
+
|
|
314
|
+
# Run smoke tests on new environment
|
|
315
|
+
echo "Running smoke tests on $NEW_ENV..."
|
|
316
|
+
if ! ./smoke-tests.sh $NEW_ENV; then
|
|
317
|
+
echo "✗ Smoke tests failed. Aborting deployment."
|
|
318
|
+
exit 1
|
|
319
|
+
fi
|
|
320
|
+
|
|
321
|
+
# Update configuration
|
|
322
|
+
echo "Updating configuration to $NEW_ENV..."
|
|
323
|
+
cat > /etc/nginx/conf.d/active-env.conf << EOF
|
|
324
|
+
upstream active_backend {
|
|
325
|
+
server ${NEW_ENV}-1:8080;
|
|
326
|
+
server ${NEW_ENV}-2:8080;
|
|
327
|
+
}
|
|
328
|
+
EOF
|
|
329
|
+
|
|
330
|
+
# Test configuration
|
|
331
|
+
if ! nginx -t; then
|
|
332
|
+
echo "✗ Configuration test failed. Reverting..."
|
|
333
|
+
cat > /etc/nginx/conf.d/active-env.conf << EOF
|
|
334
|
+
upstream active_backend {
|
|
335
|
+
server ${CURRENT_ENV}-1:8080;
|
|
336
|
+
server ${CURRENT_ENV}-2:8080;
|
|
337
|
+
}
|
|
338
|
+
EOF
|
|
339
|
+
exit 1
|
|
340
|
+
fi
|
|
341
|
+
|
|
342
|
+
# Reload Nginx
|
|
343
|
+
nginx -s reload
|
|
344
|
+
|
|
345
|
+
# Verify health
|
|
346
|
+
sleep 2
|
|
347
|
+
if curl -sf $HEALTH_ENDPOINT; then
|
|
348
|
+
echo "✓ Successfully switched to $NEW_ENV"
|
|
349
|
+
else
|
|
350
|
+
echo "✗ Health check failed. Rolling back..."
|
|
351
|
+
cat > /etc/nginx/conf.d/active-env.conf << EOF
|
|
352
|
+
upstream active_backend {
|
|
353
|
+
server ${CURRENT_ENV}-1:8080;
|
|
354
|
+
server ${CURRENT_ENV}-2:8080;
|
|
355
|
+
}
|
|
356
|
+
EOF
|
|
357
|
+
nginx -s reload
|
|
358
|
+
exit 1
|
|
359
|
+
fi
|
|
360
|
+
</code></pre><h3 id="23-canary-deployment-automation"><strong>2.3. Canary Deployment Automation</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
361
|
+
# /usr/local/bin/nginx-canary.sh
|
|
362
|
+
|
|
363
|
+
CANARY_PERCENTAGE=${1:-10}
|
|
364
|
+
MONITOR_DURATION=${2:-300} # 5 minutes
|
|
365
|
+
|
|
366
|
+
echo "Starting canary deployment with $CANARY_PERCENTAGE% traffic"
|
|
367
|
+
|
|
368
|
+
# Update canary percentage
|
|
369
|
+
sed -i "s/split_clients.*{/split_clients \"\${remote_addr}\" \$version {\n ${CANARY_PERCENTAGE}% \"canary\";/" /etc/nginx/conf.d/canary.conf
|
|
370
|
+
|
|
371
|
+
# Reload Nginx
|
|
372
|
+
nginx -s reload
|
|
373
|
+
|
|
374
|
+
# Monitor for errors
|
|
375
|
+
echo "Monitoring canary deployment for $MONITOR_DURATION seconds..."
|
|
376
|
+
START_TIME=$(date +%s)
|
|
377
|
+
ERROR_THRESHOLD=5
|
|
378
|
+
|
|
379
|
+
while [ $(($(date +%s) - START_TIME)) -lt $MONITOR_DURATION ]; do
|
|
380
|
+
# Check error rate
|
|
381
|
+
ERROR_RATE=$(tail -100 /var/log/nginx/access.log | grep "canary" | grep -c " 5[0-9][0-9] ")
|
|
382
|
+
|
|
383
|
+
if [ $ERROR_RATE -gt $ERROR_THRESHOLD ]; then
|
|
384
|
+
echo "✗ High error rate detected ($ERROR_RATE errors). Rolling back canary..."
|
|
385
|
+
sed -i "s/split_clients.*{/split_clients \"\${remote_addr}\" \$version {\n 0% \"canary\";/" /etc/nginx/conf.d/canary.conf
|
|
386
|
+
nginx -s reload
|
|
387
|
+
exit 1
|
|
388
|
+
fi
|
|
389
|
+
|
|
390
|
+
echo "Canary health: $ERROR_RATE errors (threshold: $ERROR_THRESHOLD)"
|
|
391
|
+
sleep 30
|
|
392
|
+
done
|
|
393
|
+
|
|
394
|
+
echo "✓ Canary deployment successful. Increasing to 100%..."
|
|
395
|
+
sed -i "s/split_clients.*{/split_clients \"\${remote_addr}\" \$version {\n 100% \"canary\";/" /etc/nginx/conf.d/canary.conf
|
|
396
|
+
nginx -s reload
|
|
397
|
+
</code></pre><h3 id="24-rollback-procedure"><strong>2.4. Rollback Procedure</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
398
|
+
# /usr/local/bin/nginx-rollback.sh
|
|
399
|
+
|
|
400
|
+
BACKUP_DIR="/backup/nginx/deployments"
|
|
401
|
+
|
|
402
|
+
echo "Available backups:"
|
|
403
|
+
ls -lt $BACKUP_DIR | tail -n +2 | nl
|
|
404
|
+
|
|
405
|
+
read -p "Enter backup number to restore: " BACKUP_NUM
|
|
406
|
+
|
|
407
|
+
BACKUP_PATH=$(ls -t $BACKUP_DIR | sed -n "${BACKUP_NUM}p")
|
|
408
|
+
|
|
409
|
+
if [ -z "$BACKUP_PATH" ]; then
|
|
410
|
+
echo "Invalid backup number"
|
|
411
|
+
exit 1
|
|
412
|
+
fi
|
|
413
|
+
|
|
414
|
+
echo "Rolling back to: $BACKUP_PATH"
|
|
415
|
+
read -p "Are you sure? (yes/no): " CONFIRM
|
|
416
|
+
|
|
417
|
+
if [ "$CONFIRM" != "yes" ]; then
|
|
418
|
+
echo "Rollback cancelled"
|
|
419
|
+
exit 0
|
|
420
|
+
fi
|
|
421
|
+
|
|
422
|
+
# Stop Nginx
|
|
423
|
+
systemctl stop nginx
|
|
424
|
+
|
|
425
|
+
# Backup current (failed) configuration
|
|
426
|
+
FAILED_BACKUP="/backup/nginx/failed-$(date +%Y%m%d-%H%M%S)"
|
|
427
|
+
mv /etc/nginx $FAILED_BACKUP
|
|
428
|
+
|
|
429
|
+
# Restore backup
|
|
430
|
+
cp -r $BACKUP_DIR/$BACKUP_PATH /etc/nginx
|
|
431
|
+
|
|
432
|
+
# Test configuration
|
|
433
|
+
if nginx -t; then
|
|
434
|
+
# Start Nginx
|
|
435
|
+
systemctl start nginx
|
|
436
|
+
|
|
437
|
+
# Verify
|
|
438
|
+
if systemctl is-active --quiet nginx; then
|
|
439
|
+
echo "✓ Rollback successful"
|
|
440
|
+
echo "Failed configuration saved to: $FAILED_BACKUP"
|
|
441
|
+
else
|
|
442
|
+
echo "✗ Nginx failed to start after rollback"
|
|
443
|
+
exit 1
|
|
444
|
+
fi
|
|
445
|
+
else
|
|
446
|
+
echo "✗ Backup configuration is invalid"
|
|
447
|
+
exit 1
|
|
448
|
+
fi
|
|
449
|
+
</code></pre><hr><h2 id="3-comprehensive-troubleshooting-guide"><strong>3. Comprehensive Troubleshooting Guide</strong></h2><h3 id="31-common-issues-and-solutions"><strong>3.1. Common Issues and Solutions</strong></h3><p><strong>Issue 1: 502 Bad Gateway</strong></p><pre><code class="language-bash"># Diagnosis script
|
|
450
|
+
#!/bin/bash
|
|
451
|
+
echo "Diagnosing 502 Bad Gateway errors..."
|
|
452
|
+
|
|
453
|
+
# Check if backend is running
|
|
454
|
+
echo "1. Checking backend services..."
|
|
455
|
+
for port in 8080 8081 8082; do
|
|
456
|
+
if netstat -tuln | grep -q ":$port "; then
|
|
457
|
+
echo "✓ Service on port $port is running"
|
|
458
|
+
else
|
|
459
|
+
echo "✗ No service on port $port"
|
|
460
|
+
fi
|
|
461
|
+
done
|
|
462
|
+
|
|
463
|
+
# Check Nginx error log
|
|
464
|
+
echo -e "\n2. Recent 502 errors:"
|
|
465
|
+
tail -50 /var/log/nginx/error.log | grep "502"
|
|
466
|
+
|
|
467
|
+
# Check upstream configuration
|
|
468
|
+
echo -e "\n3. Upstream configuration:"
|
|
469
|
+
nginx -T | grep -A5 "upstream"
|
|
470
|
+
|
|
471
|
+
# Test backend connectivity
|
|
472
|
+
echo -e "\n4. Testing backend connectivity:"
|
|
473
|
+
for backend in backend1:8080 backend2:8080; do
|
|
474
|
+
if curl -sf http://$backend/health; then
|
|
475
|
+
echo "✓ $backend is reachable"
|
|
476
|
+
else
|
|
477
|
+
echo "✗ $backend is not reachable"
|
|
478
|
+
fi
|
|
479
|
+
done
|
|
480
|
+
|
|
481
|
+
# Check system resources
|
|
482
|
+
echo -e "\n5. System resources:"
|
|
483
|
+
echo "Memory: $(free -h | grep Mem | awk '{print $3 "/" $2}')"
|
|
484
|
+
echo "CPU: $(top -bn1 | grep "Cpu(s)" | awk '{print $2}')%"
|
|
485
|
+
echo "Open files: $(lsof | wc -l)"
|
|
486
|
+
</code></pre><p><strong>Solutions:</strong></p><pre><code class="language-nginx"># Fix 1: Increase timeouts
|
|
487
|
+
location / {
|
|
488
|
+
proxy_pass http://backend;
|
|
489
|
+
proxy_connect_timeout 10s;
|
|
490
|
+
proxy_send_timeout 60s;
|
|
491
|
+
proxy_read_timeout 60s;
|
|
492
|
+
}
|
|
493
|
+
|
|
494
|
+
# Fix 2: Add backup server
|
|
495
|
+
upstream backend {
|
|
496
|
+
server backend1:8080 max_fails=3 fail_timeout=30s;
|
|
497
|
+
server backend2:8080 max_fails=3 fail_timeout=30s;
|
|
498
|
+
server backup-server:8080 backup;
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
# Fix 3: Use socket instead of TCP
|
|
502
|
+
upstream backend {
|
|
503
|
+
server unix:/var/run/app.sock;
|
|
504
|
+
}
|
|
505
|
+
</code></pre><p><strong>Issue 2: High Memory Usage</strong></p><pre><code class="language-bash">#!/bin/bash
|
|
506
|
+
# diagnose-memory.sh
|
|
507
|
+
|
|
508
|
+
echo "Nginx Memory Diagnosis"
|
|
509
|
+
echo "====================="
|
|
510
|
+
|
|
511
|
+
# Total memory used by Nginx
|
|
512
|
+
NGINX_MEM=$(ps aux | grep nginx | awk '{sum+=$6} END {print sum/1024}')
|
|
513
|
+
echo "Total Nginx memory: ${NGINX_MEM}MB"
|
|
514
|
+
|
|
515
|
+
# Memory per worker
|
|
516
|
+
echo -e "\nMemory per worker:"
|
|
517
|
+
ps aux | grep "nginx: worker" | awk '{print $2, $6/1024 "MB"}'
|
|
518
|
+
|
|
519
|
+
# Check buffer sizes
|
|
520
|
+
echo -e "\nBuffer configuration:"
|
|
521
|
+
nginx -T | grep -E "buffer_size|buffers"
|
|
522
|
+
|
|
523
|
+
# Check cache size
|
|
524
|
+
echo -e "\nCache usage:"
|
|
525
|
+
du -sh /var/cache/nginx/*
|
|
526
|
+
|
|
527
|
+
# Recommendations
|
|
528
|
+
echo -e "\nRecommendations:"
|
|
529
|
+
if (( $(echo "$NGINX_MEM > 1000" | bc -l) )); then
|
|
530
|
+
echo "⚠ High memory usage detected"
|
|
531
|
+
echo " - Reduce worker_connections"
|
|
532
|
+
echo " - Decrease buffer sizes"
|
|
533
|
+
echo " - Limit cache size"
|
|
534
|
+
fi
|
|
535
|
+
</code></pre><p><strong>Solutions:</strong></p><pre><code class="language-nginx"># Reduce buffer sizes
|
|
536
|
+
http {
|
|
537
|
+
client_body_buffer_size 64k; # Was: 128k
|
|
538
|
+
proxy_buffers 8 4k; # Was: 16 8k
|
|
539
|
+
|
|
540
|
+
# Limit cache
|
|
541
|
+
proxy_cache_path /var/cache/nginx
|
|
542
|
+
levels=1:2
|
|
543
|
+
keys_zone=cache:10m
|
|
544
|
+
max_size=500m # Was: 2g
|
|
545
|
+
inactive=30m;
|
|
546
|
+
}
|
|
547
|
+
</code></pre><p><strong>Issue 3: Slow Response Times</strong></p><pre><code class="language-bash">#!/bin/bash
|
|
548
|
+
# diagnose-performance.sh
|
|
549
|
+
|
|
550
|
+
echo "Performance Diagnosis"
|
|
551
|
+
echo "===================="
|
|
552
|
+
|
|
553
|
+
# Average response time
|
|
554
|
+
echo "Average response time (last 1000 requests):"
|
|
555
|
+
tail -1000 /var/log/nginx/access.log | awk '{print $NF}' | awk '{sum+=$1; count++} END {print sum/count "s"}'
|
|
556
|
+
|
|
557
|
+
# Slow requests (> 5s)
|
|
558
|
+
echo -e "\nSlow requests (>5s):"
|
|
559
|
+
tail -1000 /var/log/nginx/access.log | awk '$NF > 5 {print $0}' | head -10
|
|
560
|
+
|
|
561
|
+
# Upstream response times
|
|
562
|
+
echo -e "\nUpstream response times:"
|
|
563
|
+
tail -1000 /var/log/nginx/access.log | grep -oP 'upstream_response_time=\K[^ ]+' | awk '{sum+=$1; count++} END {print sum/count "s"}'
|
|
564
|
+
|
|
565
|
+
# Check for bottlenecks
|
|
566
|
+
echo -e "\nPotential bottlenecks:"
|
|
567
|
+
|
|
568
|
+
# Connection count
|
|
569
|
+
CONNECTIONS=$(netstat -an | grep :80 | wc -l)
|
|
570
|
+
echo "Active connections: $CONNECTIONS"
|
|
571
|
+
|
|
572
|
+
# Worker processes
|
|
573
|
+
WORKERS=$(ps aux | grep "nginx: worker" | wc -l)
|
|
574
|
+
echo "Worker processes: $WORKERS"
|
|
575
|
+
|
|
576
|
+
# CPU usage
|
|
577
|
+
CPU=$(top -bn1 | grep "Cpu(s)" | awk '{print $2}')
|
|
578
|
+
echo "CPU usage: $CPU%"
|
|
579
|
+
</code></pre><p><strong>Solutions:</strong></p><pre><code class="language-nginx"># Enable caching
|
|
580
|
+
location / {
|
|
581
|
+
proxy_pass http://backend;
|
|
582
|
+
|
|
583
|
+
proxy_cache my_cache;
|
|
584
|
+
proxy_cache_valid 200 10m;
|
|
585
|
+
proxy_cache_use_stale error timeout updating;
|
|
586
|
+
add_header X-Cache-Status $upstream_cache_status;
|
|
587
|
+
}
|
|
588
|
+
|
|
589
|
+
# Enable keepalive
|
|
590
|
+
upstream backend {
|
|
591
|
+
server backend1:8080;
|
|
592
|
+
server backend2:8080;
|
|
593
|
+
keepalive 64;
|
|
594
|
+
}
|
|
595
|
+
|
|
596
|
+
location / {
|
|
597
|
+
proxy_pass http://backend;
|
|
598
|
+
proxy_http_version 1.1;
|
|
599
|
+
proxy_set_header Connection "";
|
|
600
|
+
}
|
|
601
|
+
|
|
602
|
+
# Increase worker processes
|
|
603
|
+
worker_processes auto; # Or specific number based on CPU cores
|
|
604
|
+
</code></pre><h3 id="32-debugging-tools"><strong>3.2. Debugging Tools</strong></h3><p><strong>Real-time log monitoring:</strong></p><pre><code class="language-bash">#!/bin/bash
|
|
605
|
+
# nginx-monitor.sh
|
|
606
|
+
|
|
607
|
+
# Color codes
|
|
608
|
+
RED='\033[0;31m'
|
|
609
|
+
YELLOW='\033[1;33m'
|
|
610
|
+
GREEN='\033[0;32m'
|
|
611
|
+
NC='\033[0m'
|
|
612
|
+
|
|
613
|
+
echo "Monitoring Nginx logs... (Ctrl+C to stop)"
|
|
614
|
+
|
|
615
|
+
tail -f /var/log/nginx/access.log | while read line; do
|
|
616
|
+
STATUS=$(echo $line | awk '{print $9}')
|
|
617
|
+
|
|
618
|
+
case $STATUS in
|
|
619
|
+
2*)
|
|
620
|
+
echo -e "${GREEN}$line${NC}"
|
|
621
|
+
;;
|
|
622
|
+
3*)
|
|
623
|
+
echo -e "$line"
|
|
624
|
+
;;
|
|
625
|
+
4*)
|
|
626
|
+
echo -e "${YELLOW}$line${NC}"
|
|
627
|
+
;;
|
|
628
|
+
5*)
|
|
629
|
+
echo -e "${RED}$line${NC}"
|
|
630
|
+
;;
|
|
631
|
+
*)
|
|
632
|
+
echo "$line"
|
|
633
|
+
;;
|
|
634
|
+
esac
|
|
635
|
+
done
|
|
636
|
+
</code></pre><p><strong>Request analyzer:</strong></p><pre><code class="language-bash">#!/bin/bash
|
|
637
|
+
# analyze-requests.sh
|
|
638
|
+
|
|
639
|
+
LOG_FILE="/var/log/nginx/access.log"
|
|
640
|
+
LINES=${1:-1000}
|
|
641
|
+
|
|
642
|
+
echo "Analyzing last $LINES requests..."
|
|
643
|
+
echo "================================"
|
|
644
|
+
|
|
645
|
+
# Top URLs
|
|
646
|
+
echo -e "\nTop 10 URLs:"
|
|
647
|
+
tail -$LINES $LOG_FILE | awk '{print $7}' | sort | uniq -c | sort -rn | head -10
|
|
648
|
+
|
|
649
|
+
# Status code distribution
|
|
650
|
+
echo -e "\nStatus Code Distribution:"
|
|
651
|
+
tail -$LINES $LOG_FILE | awk '{print $9}' | sort | uniq -c | sort -rn
|
|
652
|
+
|
|
653
|
+
# Top IPs
|
|
654
|
+
echo -e "\nTop 10 IP Addresses:"
|
|
655
|
+
tail -$LINES $LOG_FILE | awk '{print $1}' | sort | uniq -c | sort -rn | head -10
|
|
656
|
+
|
|
657
|
+
# Average response time
|
|
658
|
+
echo -e "\nAverage Response Time:"
|
|
659
|
+
tail -$LINES $LOG_FILE | awk '{print $NF}' | awk '{sum+=$1; count++} END {print sum/count "s"}'
|
|
660
|
+
|
|
661
|
+
# Requests per second
|
|
662
|
+
echo -e "\nRequests per Second:"
|
|
663
|
+
tail -$LINES $LOG_FILE | awk '{print $4}' | cut -d: -f1-3 | uniq -c | awk '{sum+=$1; count++} END {print sum/count " req/s"}'
|
|
664
|
+
|
|
665
|
+
# Top User Agents
|
|
666
|
+
echo -e "\nTop 5 User Agents:"
|
|
667
|
+
tail -$LINES $LOG_FILE | awk -F'"' '{print $6}' | sort | uniq -c | sort -rn | head -5
|
|
668
|
+
</code></pre><h3 id="33-performance-testing"><strong>3.3. Performance Testing</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
669
|
+
# performance-test.sh
|
|
670
|
+
|
|
671
|
+
URL=${1:-"http://localhost"}
|
|
672
|
+
DURATION=${2:-60}
|
|
673
|
+
CONCURRENCY=${3:-100}
|
|
674
|
+
|
|
675
|
+
echo "Performance Test"
|
|
676
|
+
echo "================"
|
|
677
|
+
echo "URL: $URL"
|
|
678
|
+
echo "Duration: ${DURATION}s"
|
|
679
|
+
echo "Concurrency: $CONCURRENCY"
|
|
680
|
+
echo ""
|
|
681
|
+
|
|
682
|
+
# Test 1: Apache Bench
|
|
683
|
+
echo "Test 1: Apache Bench"
|
|
684
|
+
ab -t $DURATION -c $CONCURRENCY -k $URL/ | grep -E "Requests per second|Time per request|Transfer rate"
|
|
685
|
+
|
|
686
|
+
echo ""
|
|
687
|
+
|
|
688
|
+
# Test 2: wrk
|
|
689
|
+
echo "Test 2: wrk (if available)"
|
|
690
|
+
if command -v wrk &> /dev/null; then
|
|
691
|
+
wrk -t4 -c$CONCURRENCY -d${DURATION}s $URL/
|
|
692
|
+
else
|
|
693
|
+
echo "wrk not installed"
|
|
694
|
+
fi
|
|
695
|
+
|
|
696
|
+
echo ""
|
|
697
|
+
|
|
698
|
+
# Test 3: Siege
|
|
699
|
+
echo "Test 3: Siege (if available)"
|
|
700
|
+
if command -v siege &> /dev/null; then
|
|
701
|
+
siege -c $CONCURRENCY -t ${DURATION}s $URL
|
|
702
|
+
else
|
|
703
|
+
echo "siege not installed"
|
|
704
|
+
fi
|
|
705
|
+
</code></pre><hr><h2 id="4-security-hardening"><strong>4. Security Hardening</strong></h2><h3 id="41-complete-security-configuration"><strong>4.1. Complete Security Configuration</strong></h3><pre><code class="language-nginx"># /etc/nginx/conf.d/security.conf
|
|
706
|
+
|
|
707
|
+
# Hide server version
|
|
708
|
+
server_tokens off;
|
|
709
|
+
more_clear_headers Server;
|
|
710
|
+
|
|
711
|
+
# Limit request size
|
|
712
|
+
client_max_body_size 10M;
|
|
713
|
+
client_body_buffer_size 128k;
|
|
714
|
+
client_header_buffer_size 1k;
|
|
715
|
+
large_client_header_buffers 4 8k;
|
|
716
|
+
|
|
717
|
+
# Timeouts
|
|
718
|
+
client_body_timeout 12s;
|
|
719
|
+
client_header_timeout 12s;
|
|
720
|
+
send_timeout 10s;
|
|
721
|
+
keepalive_timeout 30s;
|
|
722
|
+
|
|
723
|
+
# Rate limiting
|
|
724
|
+
limit_req_zone $binary_remote_addr zone=general:10m rate=10r/s;
|
|
725
|
+
limit_req_zone $binary_remote_addr zone=login:10m rate=5r/m;
|
|
726
|
+
limit_conn_zone $binary_remote_addr zone=addr:10m;
|
|
727
|
+
|
|
728
|
+
# Block bad bots
|
|
729
|
+
map $http_user_agent $bad_bot {
|
|
730
|
+
default 0;
|
|
731
|
+
~*malicious 1;
|
|
732
|
+
~*scraper 1;
|
|
733
|
+
~*bot 1;
|
|
734
|
+
}
|
|
735
|
+
|
|
736
|
+
# Block suspicious URIs
|
|
737
|
+
map $request_uri $suspicious_uri {
|
|
738
|
+
default 0;
|
|
739
|
+
~*\.\./\.\. 1;
|
|
740
|
+
~*\.(bash|git|svn|env) 1;
|
|
741
|
+
~*\.(php|asp|jsp)\. 1;
|
|
742
|
+
}
|
|
743
|
+
|
|
744
|
+
# SSL/TLS configuration
|
|
745
|
+
ssl_protocols TLSv1.2 TLSv1.3;
|
|
746
|
+
ssl_prefer_server_ciphers off;
|
|
747
|
+
ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384;
|
|
748
|
+
ssl_session_cache shared:SSL:10m;
|
|
749
|
+
ssl_session_timeout 10m;
|
|
750
|
+
ssl_session_tickets off;
|
|
751
|
+
|
|
752
|
+
# Security headers template
|
|
753
|
+
map $sent_http_content_type $security_headers {
|
|
754
|
+
default "default-src 'self'; script-src 'self' 'unsafe-inline'; style-src 'self' 'unsafe-inline';";
|
|
755
|
+
}
|
|
756
|
+
</code></pre><h3 id="42-waf-rules"><strong>4.2. WAF Rules</strong></h3><pre><code class="language-nginx"># /etc/nginx/conf.d/waf-rules.conf
|
|
757
|
+
|
|
758
|
+
# SQL Injection
|
|
759
|
+
map $args $sql_injection {
|
|
760
|
+
default 0;
|
|
761
|
+
~*union.*select 1;
|
|
762
|
+
~*concat.*\( 1;
|
|
763
|
+
~*load_file 1;
|
|
764
|
+
}
|
|
765
|
+
|
|
766
|
+
# XSS Detection
|
|
767
|
+
map $args $xss_attack {
|
|
768
|
+
default 0;
|
|
769
|
+
~*<script 1;
|
|
770
|
+
~*javascript: 1;
|
|
771
|
+
~*onerror= 1;
|
|
772
|
+
}
|
|
773
|
+
|
|
774
|
+
# Path Traversal
|
|
775
|
+
map $request_uri $path_traversal {
|
|
776
|
+
default 0;
|
|
777
|
+
~*\.\./\.\. 1;
|
|
778
|
+
~*etc/passwd 1;
|
|
779
|
+
}
|
|
780
|
+
|
|
781
|
+
# Server block with WAF
|
|
782
|
+
server {
|
|
783
|
+
listen 80;
|
|
784
|
+
|
|
785
|
+
# Block attacks
|
|
786
|
+
if ($sql_injection) {
|
|
787
|
+
return 403 "SQL Injection detected";
|
|
788
|
+
}
|
|
789
|
+
|
|
790
|
+
if ($xss_attack) {
|
|
791
|
+
return 403 "XSS Attack detected";
|
|
792
|
+
}
|
|
793
|
+
|
|
794
|
+
if ($path_traversal) {
|
|
795
|
+
return 403 "Path Traversal detected";
|
|
796
|
+
}
|
|
797
|
+
|
|
798
|
+
location / {
|
|
799
|
+
proxy_pass http://backend;
|
|
800
|
+
}
|
|
801
|
+
}
|
|
802
|
+
</code></pre><h3 id="43-ddos-protection"><strong>4.3. DDoS Protection</strong></h3><pre><code class="language-nginx"># /etc/nginx/conf.d/ddos-protection.conf
|
|
803
|
+
|
|
804
|
+
# Connection limits
|
|
805
|
+
limit_conn_zone $binary_remote_addr zone=conn_limit_per_ip:10m;
|
|
806
|
+
limit_conn_zone $server_name zone=conn_limit_per_server:10m;
|
|
807
|
+
|
|
808
|
+
# Request rate limits
|
|
809
|
+
limit_req_zone $binary_remote_addr zone=req_limit_per_ip:10m rate=10r/s;
|
|
810
|
+
|
|
811
|
+
# Slow request protection
|
|
812
|
+
client_body_timeout 10s;
|
|
813
|
+
client_header_timeout 10s;
|
|
814
|
+
send_timeout 10s;
|
|
815
|
+
|
|
816
|
+
# Small buffer to prevent slowloris
|
|
817
|
+
client_body_buffer_size 1k;
|
|
818
|
+
client_header_buffer_size 1k;
|
|
819
|
+
large_client_header_buffers 2 1k;
|
|
820
|
+
|
|
821
|
+
server {
|
|
822
|
+
listen 80;
|
|
823
|
+
|
|
824
|
+
# Apply limits
|
|
825
|
+
limit_conn conn_limit_per_ip 10;
|
|
826
|
+
limit_conn conn_limit_per_server 1000;
|
|
827
|
+
limit_req zone=req_limit_per_ip burst=20 nodelay;
|
|
828
|
+
|
|
829
|
+
location / {
|
|
830
|
+
proxy_pass http://backend;
|
|
831
|
+
}
|
|
832
|
+
}
|
|
833
|
+
</code></pre><h3 id="44-security-monitoring"><strong>4.4. Security Monitoring</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
834
|
+
# security-monitor.sh
|
|
835
|
+
|
|
836
|
+
LOG_FILE="/var/log/nginx/access.log"
|
|
837
|
+
ALERT_EMAIL="security@example.com"
|
|
838
|
+
WEBHOOK_URL="https://hooks.slack.com/services/YOUR/WEBHOOK"
|
|
839
|
+
|
|
840
|
+
# Monitor for attacks
|
|
841
|
+
tail -f $LOG_FILE | while read line; do
|
|
842
|
+
# SQL Injection
|
|
843
|
+
if echo "$line" | grep -qE "union.*select|concat\("; then
|
|
844
|
+
echo "[ALERT] SQL Injection attempt: $line"
|
|
845
|
+
echo "SQL Injection attempt detected" | mail -s "Security Alert" $ALERT_EMAIL
|
|
846
|
+
curl -X POST $WEBHOOK_URL -d "{\"text\":\"🔴 SQL Injection attempt detected\"}"
|
|
847
|
+
fi
|
|
848
|
+
|
|
849
|
+
# XSS
|
|
850
|
+
if echo "$line" | grep -qE "<script|javascript:"; then
|
|
851
|
+
echo "[ALERT] XSS attempt: $line"
|
|
852
|
+
fi
|
|
853
|
+
|
|
854
|
+
# Directory traversal
|
|
855
|
+
if echo "$line" | grep -qE "\.\./\.\."; then
|
|
856
|
+
echo "[ALERT] Directory traversal attempt: $line"
|
|
857
|
+
fi
|
|
858
|
+
|
|
859
|
+
# High rate from single IP
|
|
860
|
+
IP=$(echo "$line" | awk '{print $1}')
|
|
861
|
+
COUNT=$(grep "$IP" $LOG_FILE | wc -l)
|
|
862
|
+
if [ $COUNT -gt 1000 ]; then
|
|
863
|
+
echo "[ALERT] High request rate from $IP: $COUNT requests"
|
|
864
|
+
fi
|
|
865
|
+
done
|
|
866
|
+
</code></pre><hr><h2 id="5-cost-optimization"><strong>5. Cost Optimization</strong></h2><h3 id="51-bandwidth-optimization"><strong>5.1. Bandwidth Optimization</strong></h3><pre><code class="language-nginx"># Compression
|
|
867
|
+
http {
|
|
868
|
+
gzip on;
|
|
869
|
+
gzip_vary on;
|
|
870
|
+
gzip_proxied any;
|
|
871
|
+
gzip_comp_level 6;
|
|
872
|
+
gzip_types text/plain text/css text/xml text/javascript
|
|
873
|
+
application/json application/javascript application/xml+rss
|
|
874
|
+
image/svg+xml;
|
|
875
|
+
gzip_min_length 1000;
|
|
876
|
+
|
|
877
|
+
# Brotli (if available)
|
|
878
|
+
brotli on;
|
|
879
|
+
brotli_comp_level 6;
|
|
880
|
+
brotli_types text/plain text/css text/xml text/javascript
|
|
881
|
+
application/json application/javascript;
|
|
882
|
+
}
|
|
883
|
+
|
|
884
|
+
# Aggressive caching
|
|
885
|
+
location ~* \.(jpg|jpeg|png|gif|ico|css|js|svg|woff|woff2)$ {
|
|
886
|
+
expires 1y;
|
|
887
|
+
add_header Cache-Control "public, immutable";
|
|
888
|
+
access_log off;
|
|
889
|
+
}
|
|
890
|
+
|
|
891
|
+
# Remove unnecessary headers
|
|
892
|
+
more_clear_headers Server;
|
|
893
|
+
more_clear_headers X-Powered-By;
|
|
894
|
+
</code></pre><h3 id="52-resource-optimization"><strong>5.2. Resource Optimization</strong></h3><pre><code class="language-nginx"># Optimize worker configuration
|
|
895
|
+
worker_processes auto;
|
|
896
|
+
worker_rlimit_nofile 65535;
|
|
897
|
+
|
|
898
|
+
events {
|
|
899
|
+
worker_connections 2048; # Don't over-provision
|
|
900
|
+
use epoll;
|
|
901
|
+
multi_accept on;
|
|
902
|
+
}
|
|
903
|
+
|
|
904
|
+
http {
|
|
905
|
+
# Connection pooling
|
|
906
|
+
keepalive_timeout 30s; # Not too long
|
|
907
|
+
keepalive_requests 100;
|
|
908
|
+
|
|
909
|
+
# Upstream keepalive
|
|
910
|
+
upstream backend {
|
|
911
|
+
server backend1:8080;
|
|
912
|
+
keepalive 32; # Reasonable size
|
|
913
|
+
}
|
|
914
|
+
|
|
915
|
+
# Efficient file serving
|
|
916
|
+
sendfile on;
|
|
917
|
+
tcp_nopush on;
|
|
918
|
+
tcp_nodelay on;
|
|
919
|
+
|
|
920
|
+
# File cache
|
|
921
|
+
open_file_cache max=1000 inactive=20s;
|
|
922
|
+
open_file_cache_valid 30s;
|
|
923
|
+
open_file_cache_min_uses 2;
|
|
924
|
+
}
|
|
925
|
+
</code></pre><h3 id="53-cost-monitoring"><strong>5.3. Cost Monitoring</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
926
|
+
# cost-report.sh
|
|
927
|
+
|
|
928
|
+
echo "Nginx Cost Report"
|
|
929
|
+
echo "================="
|
|
930
|
+
|
|
931
|
+
# Bandwidth usage
|
|
932
|
+
echo -e "\n1. Bandwidth Usage (last 24 hours):"
|
|
933
|
+
BYTES=$(awk '{sum+=$10} END {print sum}' /var/log/nginx/access.log)
|
|
934
|
+
GB=$(echo "scale=2; $BYTES / 1024 / 1024 / 1024" | bc)
|
|
935
|
+
echo "Total: ${GB}GB"
|
|
936
|
+
|
|
937
|
+
# Request count
|
|
938
|
+
echo -e "\n2. Request Count:"
|
|
939
|
+
REQUESTS=$(wc -l < /var/log/nginx/access.log)
|
|
940
|
+
echo "Total requests: $REQUESTS"
|
|
941
|
+
|
|
942
|
+
# Cache hit rate
|
|
943
|
+
echo -e "\n3. Cache Performance:"
|
|
944
|
+
HITS=$(grep "HIT" /var/log/nginx/access.log | wc -l)
|
|
945
|
+
TOTAL=$(wc -l < /var/log/nginx/access.log)
|
|
946
|
+
HIT_RATE=$(echo "scale=2; ($HITS * 100) / $TOTAL" | bc)
|
|
947
|
+
echo "Cache hit rate: ${HIT_RATE}%"
|
|
948
|
+
|
|
949
|
+
# Compression savings
|
|
950
|
+
echo -e "\n4. Compression Savings:"
|
|
951
|
+
UNCOMPRESSED=$(awk '{sum+=$10} END {print sum}' /var/log/nginx/access.log)
|
|
952
|
+
# Estimate 70% compression
|
|
953
|
+
COMPRESSED=$(echo "scale=2; $UNCOMPRESSED * 0.3" | bc)
|
|
954
|
+
SAVINGS=$(echo "scale=2; ($UNCOMPRESSED - $COMPRESSED) / 1024 / 1024 / 1024" | bc)
|
|
955
|
+
echo "Estimated savings: ${SAVINGS}GB"
|
|
956
|
+
|
|
957
|
+
# Recommendations
|
|
958
|
+
echo -e "\n5. Cost Optimization Recommendations:"
|
|
959
|
+
if (( $(echo "$HIT_RATE < 80" | bc -l) )); then
|
|
960
|
+
echo "⚠ Cache hit rate is low. Increase cache size."
|
|
961
|
+
fi
|
|
962
|
+
|
|
963
|
+
if ! nginx -T | grep -q "gzip on"; then
|
|
964
|
+
echo "⚠ Gzip compression is disabled. Enable it to save bandwidth."
|
|
965
|
+
fi
|
|
966
|
+
</code></pre><hr><h2 id="6-compliance-pci-dss-hipaa-gdpr"><strong>6. Compliance (PCI-DSS, HIPAA, GDPR)</strong></h2><h3 id="61-pci-dss-configuration"><strong>6.1. PCI-DSS Configuration</strong></h3><pre><code class="language-nginx"># PCI-DSS compliant configuration
|
|
967
|
+
|
|
968
|
+
http {
|
|
969
|
+
# Strong SSL/TLS only
|
|
970
|
+
ssl_protocols TLSv1.2 TLSv1.3;
|
|
971
|
+
ssl_ciphers 'ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305';
|
|
972
|
+
ssl_prefer_server_ciphers on;
|
|
973
|
+
|
|
974
|
+
# Logging for compliance
|
|
975
|
+
log_format pci_compliant '$remote_addr - $remote_user [$time_local] '
|
|
976
|
+
'"$request" $status $body_bytes_sent '
|
|
977
|
+
'"$http_referer" "$http_user_agent" '
|
|
978
|
+
'ssl_protocol=$ssl_protocol ssl_cipher=$ssl_cipher '
|
|
979
|
+
'request_id=$request_id';
|
|
980
|
+
|
|
981
|
+
access_log /var/log/nginx/pci-access.log pci_compliant;
|
|
982
|
+
|
|
983
|
+
server {
|
|
984
|
+
listen 443 ssl http2;
|
|
985
|
+
|
|
986
|
+
# No weak ciphers
|
|
987
|
+
ssl_ciphers HIGH:!aNULL:!MD5:!3DES;
|
|
988
|
+
|
|
989
|
+
# Certificate pinning (optional)
|
|
990
|
+
add_header Public-Key-Pins 'pin-sha256="base64+primary=="; pin-sha256="base64+backup=="; max-age=5184000; includeSubDomains';
|
|
991
|
+
|
|
992
|
+
# Security headers
|
|
993
|
+
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always;
|
|
994
|
+
add_header X-Frame-Options "DENY" always;
|
|
995
|
+
add_header X-Content-Type-Options "nosniff" always;
|
|
996
|
+
|
|
997
|
+
# No credit card data in URLs
|
|
998
|
+
if ($request_uri ~* (card|cc|cvv|pan)=) {
|
|
999
|
+
return 400 "Sensitive data in URL not allowed";
|
|
1000
|
+
}
|
|
1001
|
+
|
|
1002
|
+
location / {
|
|
1003
|
+
proxy_pass http://backend;
|
|
1004
|
+
|
|
1005
|
+
# Don't log sensitive data
|
|
1006
|
+
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
1007
|
+
|
|
1008
|
+
# Secure headers
|
|
1009
|
+
proxy_hide_header X-Powered-By;
|
|
1010
|
+
}
|
|
1011
|
+
}
|
|
1012
|
+
}
|
|
1013
|
+
</code></pre><h3 id="62-hipaa-configuration"><strong>6.2. HIPAA Configuration</strong></h3><pre><code class="language-nginx"># HIPAA compliant configuration
|
|
1014
|
+
|
|
1015
|
+
http {
|
|
1016
|
+
# Encryption required
|
|
1017
|
+
ssl_protocols TLSv1.2 TLSv1.3;
|
|
1018
|
+
|
|
1019
|
+
# Detailed audit logging
|
|
1020
|
+
log_format hipaa '$remote_addr - $remote_user [$time_local] '
|
|
1021
|
+
'"$request" $status $body_bytes_sent '
|
|
1022
|
+
'request_id=$request_id '
|
|
1023
|
+
'user_agent="$http_user_agent" '
|
|
1024
|
+
'ssl_protocol=$ssl_protocol';
|
|
1025
|
+
|
|
1026
|
+
access_log /var/log/nginx/hipaa-access.log hipaa;
|
|
1027
|
+
|
|
1028
|
+
# Retain logs for 6 years (HIPAA requirement)
|
|
1029
|
+
# Configure in logrotate
|
|
1030
|
+
|
|
1031
|
+
server {
|
|
1032
|
+
listen 443 ssl http2;
|
|
1033
|
+
|
|
1034
|
+
# Strong encryption
|
|
1035
|
+
ssl_ciphers ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384;
|
|
1036
|
+
|
|
1037
|
+
# Require client certificates (mutual TLS)
|
|
1038
|
+
ssl_client_certificate /etc/nginx/ssl/ca.crt;
|
|
1039
|
+
ssl_verify_client optional;
|
|
1040
|
+
|
|
1041
|
+
# Access control
|
|
1042
|
+
if ($ssl_client_verify != SUCCESS) {
|
|
1043
|
+
return 403 "Client certificate required";
|
|
1044
|
+
}
|
|
1045
|
+
|
|
1046
|
+
# Session timeout (HIPAA requires automatic logout)
|
|
1047
|
+
add_header Set-Cookie "session_timeout=1800; Secure; HttpOnly";
|
|
1048
|
+
|
|
1049
|
+
location /api/patient-data {
|
|
1050
|
+
# Strict access controls
|
|
1051
|
+
limit_except GET POST {
|
|
1052
|
+
deny all;
|
|
1053
|
+
}
|
|
1054
|
+
|
|
1055
|
+
# Audit all access
|
|
1056
|
+
access_log /var/log/nginx/phi-access.log hipaa;
|
|
1057
|
+
|
|
1058
|
+
proxy_pass http://backend;
|
|
1059
|
+
}
|
|
1060
|
+
}
|
|
1061
|
+
}
|
|
1062
|
+
</code></pre><h3 id="63-gdpr-configuration"><strong>6.3. GDPR Configuration</strong></h3><pre><code class="language-nginx"># GDPR compliant configuration
|
|
1063
|
+
|
|
1064
|
+
http {
|
|
1065
|
+
# IP anonymization
|
|
1066
|
+
map $remote_addr $anonymized_ip {
|
|
1067
|
+
~(?P<ip>\d+\.\d+\.\d+)\.\d+ $ip.0;
|
|
1068
|
+
~(?P<ip>[^:]+:[^:]+): $ip::;
|
|
1069
|
+
default 0.0.0.0;
|
|
1070
|
+
}
|
|
1071
|
+
|
|
1072
|
+
# GDPR-compliant logging
|
|
1073
|
+
log_format gdpr '$anonymized_ip - [$time_local] '
|
|
1074
|
+
'"$request" $status $body_bytes_sent '
|
|
1075
|
+
'request_id=$request_id';
|
|
1076
|
+
|
|
1077
|
+
access_log /var/log/nginx/gdpr-access.log gdpr;
|
|
1078
|
+
|
|
1079
|
+
# Cookie consent tracking
|
|
1080
|
+
map $http_cookie $cookie_consent {
|
|
1081
|
+
default 0;
|
|
1082
|
+
~*cookie_consent=accepted 1;
|
|
1083
|
+
}
|
|
1084
|
+
|
|
1085
|
+
server {
|
|
1086
|
+
listen 443 ssl http2;
|
|
1087
|
+
|
|
1088
|
+
# Data subject rights endpoint
|
|
1089
|
+
location /api/gdpr/data-request {
|
|
1090
|
+
# Handle GDPR data requests
|
|
1091
|
+
limit_req zone=gdpr_requests burst=5;
|
|
1092
|
+
|
|
1093
|
+
proxy_pass http://backend/gdpr/request;
|
|
1094
|
+
}
|
|
1095
|
+
|
|
1096
|
+
# Tracking only with consent
|
|
1097
|
+
location /analytics {
|
|
1098
|
+
if ($cookie_consent = 0) {
|
|
1099
|
+
return 403 "Cookie consent required";
|
|
1100
|
+
}
|
|
1101
|
+
|
|
1102
|
+
proxy_pass http://analytics_backend;
|
|
1103
|
+
}
|
|
1104
|
+
|
|
1105
|
+
# Data retention policy
|
|
1106
|
+
location /api/ {
|
|
1107
|
+
# Add header about data retention
|
|
1108
|
+
add_header X-Data-Retention "30 days" always;
|
|
1109
|
+
|
|
1110
|
+
proxy_pass http://backend;
|
|
1111
|
+
}
|
|
1112
|
+
}
|
|
1113
|
+
}
|
|
1114
|
+
</code></pre><hr><h2 id="7-production-readiness-checklist"><strong>7. Production Readiness Checklist</strong></h2><h3 id="71-pre-deployment-checklist"><strong>7.1. Pre-deployment Checklist</strong></h3><pre><code class="language-markdown"># Nginx Production Readiness Checklist
|
|
1115
|
+
|
|
1116
|
+
## Configuration
|
|
1117
|
+
- [ ] Configuration tested with `nginx -t`
|
|
1118
|
+
- [ ] No syntax errors
|
|
1119
|
+
- [ ] Modular configuration structure
|
|
1120
|
+
- [ ] Configuration in version control
|
|
1121
|
+
- [ ] Backups automated
|
|
1122
|
+
|
|
1123
|
+
## Performance
|
|
1124
|
+
- [ ] Worker processes optimized (auto or based on CPU cores)
|
|
1125
|
+
- [ ] Worker connections configured (typically 2048-4096)
|
|
1126
|
+
- [ ] Keepalive enabled for upstreams
|
|
1127
|
+
- [ ] Gzip compression enabled
|
|
1128
|
+
- [ ] Static file caching configured
|
|
1129
|
+
- [ ] Proxy caching configured where appropriate
|
|
1130
|
+
- [ ] sendfile and tcp_nopush enabled
|
|
1131
|
+
- [ ] Open file cache configured
|
|
1132
|
+
|
|
1133
|
+
## Security
|
|
1134
|
+
- [ ] SSL/TLS configured (TLS 1.2+ only)
|
|
1135
|
+
- [ ] Strong ciphers configured
|
|
1136
|
+
- [ ] HSTS enabled
|
|
1137
|
+
- [ ] Security headers configured (X-Frame-Options, CSP, etc.)
|
|
1138
|
+
- [ ] Rate limiting implemented
|
|
1139
|
+
- [ ] DDoS protection configured
|
|
1140
|
+
- [ ] Server tokens hidden
|
|
1141
|
+
- [ ] Access controls (IP whitelist/blacklist)
|
|
1142
|
+
- [ ] WAF rules implemented (if needed)
|
|
1143
|
+
- [ ] Regular security updates scheduled
|
|
1144
|
+
|
|
1145
|
+
## High Availability
|
|
1146
|
+
- [ ] Multiple upstream servers configured
|
|
1147
|
+
- [ ] Health checks implemented
|
|
1148
|
+
- [ ] Failover tested
|
|
1149
|
+
- [ ] Load balancing configured
|
|
1150
|
+
- [ ] Session persistence (if needed)
|
|
1151
|
+
- [ ] Keepalived configured (if using VIP)
|
|
1152
|
+
- [ ] Disaster recovery plan documented
|
|
1153
|
+
|
|
1154
|
+
## Monitoring & Logging
|
|
1155
|
+
- [ ] Access logs configured
|
|
1156
|
+
- [ ] Error logs configured
|
|
1157
|
+
- [ ] Log rotation configured
|
|
1158
|
+
- [ ] Monitoring system integrated (Prometheus/Grafana)
|
|
1159
|
+
- [ ] Alerting configured
|
|
1160
|
+
- [ ] Health check endpoints
|
|
1161
|
+
- [ ] Metrics exported
|
|
1162
|
+
- [ ] Log aggregation (ELK/CloudWatch)
|
|
1163
|
+
|
|
1164
|
+
## Documentation
|
|
1165
|
+
- [ ] Architecture diagram created
|
|
1166
|
+
- [ ] Configuration documented
|
|
1167
|
+
- [ ] Deployment procedure documented
|
|
1168
|
+
- [ ] Rollback procedure documented
|
|
1169
|
+
- [ ] Troubleshooting guide created
|
|
1170
|
+
- [ ] On-call runbook prepared
|
|
1171
|
+
|
|
1172
|
+
## Testing
|
|
1173
|
+
- [ ] Load testing performed
|
|
1174
|
+
- [ ] Failover testing completed
|
|
1175
|
+
- [ ] Security testing done
|
|
1176
|
+
- [ ] Smoke tests automated
|
|
1177
|
+
- [ ] Performance benchmarks documented
|
|
1178
|
+
|
|
1179
|
+
## Compliance
|
|
1180
|
+
- [ ] Compliance requirements identified (PCI-DSS/HIPAA/GDPR)
|
|
1181
|
+
- [ ] Audit logging enabled
|
|
1182
|
+
- [ ] Data retention policy implemented
|
|
1183
|
+
- [ ] Access controls documented
|
|
1184
|
+
- [ ] Compliance audit scheduled
|
|
1185
|
+
</code></pre><h3 id="72-health-check-script"><strong>7.2. Health Check Script</strong></h3><pre><code class="language-bash">#!/bin/bash
|
|
1186
|
+
# production-healthcheck.sh
|
|
1187
|
+
|
|
1188
|
+
REPORT_FILE="/tmp/nginx-health-$(date +%Y%m%d).txt"
|
|
1189
|
+
|
|
1190
|
+
{
|
|
1191
|
+
echo "Nginx Production Health Check"
|
|
1192
|
+
echo "=============================="
|
|
1193
|
+
echo "Date: $(date)"
|
|
1194
|
+
echo ""
|
|
1195
|
+
|
|
1196
|
+
# 1. Service Status
|
|
1197
|
+
echo "1. Service Status"
|
|
1198
|
+
if systemctl is-active --quiet nginx; then
|
|
1199
|
+
echo "✓ Nginx is running"
|
|
1200
|
+
else
|
|
1201
|
+
echo "✗ Nginx is NOT running"
|
|
1202
|
+
fi
|
|
1203
|
+
echo ""
|
|
1204
|
+
|
|
1205
|
+
# 2. Configuration Test
|
|
1206
|
+
echo "2. Configuration Test"
|
|
1207
|
+
if nginx -t 2>&1; then
|
|
1208
|
+
echo "✓ Configuration is valid"
|
|
1209
|
+
else
|
|
1210
|
+
echo "✗ Configuration has errors"
|
|
1211
|
+
fi
|
|
1212
|
+
echo ""
|
|
1213
|
+
|
|
1214
|
+
# 3. SSL Certificate Expiry
|
|
1215
|
+
echo "3. SSL Certificate Status"
|
|
1216
|
+
for cert in /etc/letsencrypt/live/*/fullchain.pem; do
|
|
1217
|
+
DOMAIN=$(echo $cert | cut -d/ -f5)
|
|
1218
|
+
EXPIRY=$(openssl x509 -enddate -noout -in $cert | cut -d= -f2)
|
|
1219
|
+
DAYS=$(( ($(date -d "$EXPIRY" +%s) - $(date +%s)) / 86400 ))
|
|
1220
|
+
|
|
1221
|
+
if [ $DAYS -lt 30 ]; then
|
|
1222
|
+
echo "⚠ $DOMAIN expires in $DAYS days"
|
|
1223
|
+
else
|
|
1224
|
+
echo "✓ $DOMAIN valid for $DAYS days"
|
|
1225
|
+
fi
|
|
1226
|
+
done
|
|
1227
|
+
echo ""
|
|
1228
|
+
|
|
1229
|
+
# 4. Resource Usage
|
|
1230
|
+
echo "4. Resource Usage"
|
|
1231
|
+
echo "Memory: $(free -h | grep Mem | awk '{print $3 "/" $2}')"
|
|
1232
|
+
echo "CPU: $(top -bn1 | grep "Cpu(s)" | awk '{print $2}')%"
|
|
1233
|
+
echo "Disk: $(df -h / | tail -1 | awk '{print $5}')"
|
|
1234
|
+
echo ""
|
|
1235
|
+
|
|
1236
|
+
# 5. Connection Stats
|
|
1237
|
+
echo "5. Connection Stats"
|
|
1238
|
+
CONNECTIONS=$(netstat -an | grep :80 | wc -l)
|
|
1239
|
+
echo "Active connections: $CONNECTIONS"
|
|
1240
|
+
echo ""
|
|
1241
|
+
|
|
1242
|
+
# 6. Error Rate
|
|
1243
|
+
echo "6. Error Rate (last hour)"
|
|
1244
|
+
TOTAL=$(grep "$(date -d '1 hour ago' '+%d/%b/%Y:%H')" /var/log/nginx/access.log | wc -l)
|
|
1245
|
+
ERRORS=$(grep "$(date -d '1 hour ago' '+%d/%b/%Y:%H')" /var/log/nginx/access.log | grep " 5[0-9][0-9] " | wc -l)
|
|
1246
|
+
if [ $TOTAL -gt 0 ]; then
|
|
1247
|
+
ERROR_RATE=$(echo "scale=2; ($ERRORS * 100) / $TOTAL" | bc)
|
|
1248
|
+
echo "Error rate: ${ERROR_RATE}%"
|
|
1249
|
+
|
|
1250
|
+
if (( $(echo "$ERROR_RATE > 1" | bc -l) )); then
|
|
1251
|
+
echo "⚠ High error rate"
|
|
1252
|
+
else
|
|
1253
|
+
echo "✓ Error rate normal"
|
|
1254
|
+
fi
|
|
1255
|
+
fi
|
|
1256
|
+
echo ""
|
|
1257
|
+
|
|
1258
|
+
# 7. Upstream Health
|
|
1259
|
+
echo "7. Upstream Health"
|
|
1260
|
+
nginx -T 2>/dev/null | grep "server.*:.*;" | while read line; do
|
|
1261
|
+
SERVER=$(echo $line | awk '{print $2}' | tr -d ';')
|
|
1262
|
+
if curl -sf --max-time 2 http://$SERVER/health > /dev/null; then
|
|
1263
|
+
echo "✓ $SERVER is healthy"
|
|
1264
|
+
else
|
|
1265
|
+
echo "✗ $SERVER is unhealthy"
|
|
1266
|
+
fi
|
|
1267
|
+
done
|
|
1268
|
+
echo ""
|
|
1269
|
+
|
|
1270
|
+
# 8. Log Files
|
|
1271
|
+
echo "8. Log File Status"
|
|
1272
|
+
for log in /var/log/nginx/*.log; do
|
|
1273
|
+
SIZE=$(du -h $log | awk '{print $1}')
|
|
1274
|
+
echo "$(basename $log): $SIZE"
|
|
1275
|
+
done
|
|
1276
|
+
echo ""
|
|
1277
|
+
|
|
1278
|
+
# 9. Security
|
|
1279
|
+
echo "9. Security Check"
|
|
1280
|
+
if nginx -T 2>/dev/null | grep -q "ssl_protocols.*TLSv1.3"; then
|
|
1281
|
+
echo "✓ TLS 1.3 enabled"
|
|
1282
|
+
else
|
|
1283
|
+
echo "⚠ TLS 1.3 not enabled"
|
|
1284
|
+
fi
|
|
1285
|
+
|
|
1286
|
+
if nginx -T 2>/dev/null | grep -q "limit_req_zone"; then
|
|
1287
|
+
echo "✓ Rate limiting configured"
|
|
1288
|
+
else
|
|
1289
|
+
echo "⚠ Rate limiting not configured"
|
|
1290
|
+
fi
|
|
1291
|
+
echo ""
|
|
1292
|
+
|
|
1293
|
+
# 10. Overall Status
|
|
1294
|
+
echo "10. Overall Status"
|
|
1295
|
+
if systemctl is-active --quiet nginx && nginx -t 2>&1 > /dev/null; then
|
|
1296
|
+
echo "✓ System is healthy"
|
|
1297
|
+
exit 0
|
|
1298
|
+
else
|
|
1299
|
+
echo "✗ System has issues"
|
|
1300
|
+
exit 1
|
|
1301
|
+
fi
|
|
1302
|
+
|
|
1303
|
+
} | tee $REPORT_FILE
|
|
1304
|
+
|
|
1305
|
+
# Send report
|
|
1306
|
+
mail -s "Nginx Health Report" admin@example.com < $REPORT_FILE
|
|
1307
|
+
</code></pre><hr><h2 id="8-documentation-templates"><strong>8. Documentation Templates</strong></h2><h3 id="81-architecture-documentation"><strong>8.1. Architecture Documentation</strong></h3><pre><code class="language-markdown"># Nginx Architecture Documentation
|
|
1308
|
+
|
|
1309
|
+
## Overview
|
|
1310
|
+
Brief description of the architecture and purpose.
|
|
1311
|
+
|
|
1312
|
+
## Infrastructure
|
|
1313
|
+
|
|
1314
|
+
### Load Balancers
|
|
1315
|
+
- **Primary LB**: 192.168.1.10 (lb-1.example.com)
|
|
1316
|
+
- **Backup LB**: 192.168.1.11 (lb-2.example.com)
|
|
1317
|
+
- **Virtual IP**: 192.168.1.100
|
|
1318
|
+
|
|
1319
|
+
### Backend Servers
|
|
1320
|
+
- **Web-1**: 10.0.1.10 (web-1.internal)
|
|
1321
|
+
- **Web-2**: 10.0.1.11 (web-2.internal)
|
|
1322
|
+
- **Web-3**: 10.0.1.12 (web-3.internal)
|
|
1323
|
+
|
|
1324
|
+
### Databases
|
|
1325
|
+
- **Primary DB**: db-master.internal:3306
|
|
1326
|
+
- **Read Replica 1**: db-slave1.internal:3306
|
|
1327
|
+
- **Read Replica 2**: db-slave2.internal:3306
|
|
1328
|
+
|
|
1329
|
+
## Network Diagram
|
|
1330
|
+
</code></pre><p>[Internet] ↓ [Firewall] ↓ [LB-1 / LB-2] (VIP: 192.168.1.100) ↓ [Web-1 | Web-2 | Web-3] ↓ [DB Master / Read Replicas]</p><pre><code>
|
|
1331
|
+
## Configuration Files
|
|
1332
|
+
- Main config: `/etc/nginx/nginx.conf`
|
|
1333
|
+
- Site configs: `/etc/nginx/sites-enabled/`
|
|
1334
|
+
- Upstreams: `/etc/nginx/conf.d/upstreams/`
|
|
1335
|
+
|
|
1336
|
+
## SSL Certificates
|
|
1337
|
+
- Provider: Let's Encrypt
|
|
1338
|
+
- Renewal: Automated via certbot
|
|
1339
|
+
- Expiry notifications: security@example.com
|
|
1340
|
+
|
|
1341
|
+
## Monitoring
|
|
1342
|
+
- Tool: Prometheus + Grafana
|
|
1343
|
+
- Alerts: Slack #ops-alerts
|
|
1344
|
+
- Dashboards: https://grafana.example.com
|
|
1345
|
+
|
|
1346
|
+
## Backup & Recovery
|
|
1347
|
+
- Configuration backup: Daily at 02:00 UTC
|
|
1348
|
+
- Backup location: /backup/nginx and backup-server:/backups
|
|
1349
|
+
- RTO: < 5 minutes
|
|
1350
|
+
- RPO: < 1 hour
|
|
1351
|
+
|
|
1352
|
+
## Contacts
|
|
1353
|
+
- On-call: oncall@example.com
|
|
1354
|
+
- DevOps Team: devops@example.com
|
|
1355
|
+
- Security Team: security@example.com
|
|
1356
|
+
</code></pre><h3 id="82-runbook-template"><strong>8.2. Runbook Template</strong></h3><pre><code class="language-markdown"># Nginx Operations Runbook
|
|
1357
|
+
|
|
1358
|
+
## Common Operations
|
|
1359
|
+
|
|
1360
|
+
### Deploy New Configuration
|
|
1361
|
+
```bash
|
|
1362
|
+
# 1. Backup current config
|
|
1363
|
+
./nginx-config-backup.sh
|
|
1364
|
+
|
|
1365
|
+
# 2. Update configuration files
|
|
1366
|
+
rsync -av /path/to/new/config/ /etc/nginx/
|
|
1367
|
+
|
|
1368
|
+
# 3. Test configuration
|
|
1369
|
+
nginx -t
|
|
1370
|
+
|
|
1371
|
+
# 4. Reload Nginx
|
|
1372
|
+
nginx -s reload
|
|
1373
|
+
|
|
1374
|
+
# 5. Verify
|
|
1375
|
+
curl -I http://localhost/health
|
|
1376
|
+
</code></pre><h3 id="rollback-deployment">Rollback Deployment</h3><pre><code class="language-bash">./nginx-rollback.sh
|
|
1377
|
+
</code></pre><h3 id="check-service-status">Check Service Status</h3><pre><code class="language-bash">systemctl status nginx
|
|
1378
|
+
curl http://localhost/health
|
|
1379
|
+
</code></pre><h3 id="view-logs">View Logs</h3><pre><code class="language-bash"># Access logs
|
|
1380
|
+
tail -f /var/log/nginx/access.log
|
|
1381
|
+
|
|
1382
|
+
# Error logs
|
|
1383
|
+
tail -f /var/log/nginx/error.log
|
|
1384
|
+
|
|
1385
|
+
# Analyze logs
|
|
1386
|
+
./analyze-requests.sh 1000
|
|
1387
|
+
</code></pre><h2 id="troubleshooting">Troubleshooting</h2><h3 id="issue-502-bad-gateway">Issue: 502 Bad Gateway</h3><p><strong>Symptoms</strong>: Users receive 502 errors <strong>Diagnosis</strong>:</p><pre><code class="language-bash"># Check backend health
|
|
1388
|
+
curl http://backend:8080/health
|
|
1389
|
+
|
|
1390
|
+
# Check error logs
|
|
1391
|
+
tail -50 /var/log/nginx/error.log | grep 502
|
|
1392
|
+
</code></pre><p><strong>Resolution</strong>:</p><ol><li>Verify backend services are running</li><li>Check upstream configuration</li><li>Increase timeouts if needed</li><li>Restart backend services if necessary</li></ol><h3 id="issue-high-cpu-usage">Issue: High CPU Usage</h3><p><strong>Symptoms</strong>: CPU usage > 80% <strong>Diagnosis</strong>:</p><pre><code class="language-bash">top -bn1 | grep nginx
|
|
1393
|
+
./diagnose-performance.sh
|
|
1394
|
+
</code></pre><p><strong>Resolution</strong>:</p><ol><li>Check for inefficient regex in configuration</li><li>Reduce worker_connections if too high</li><li>Enable caching to reduce backend load</li><li>Scale horizontally if needed</li></ol><h3 id="issue-ssl-certificate-expired">Issue: SSL Certificate Expired</h3><p><strong>Symptoms</strong>: SSL warnings in browser <strong>Diagnosis</strong>:</p><pre><code class="language-bash">openssl x509 -enddate -noout -in /etc/letsencrypt/live/example.com/fullchain.pem
|
|
1395
|
+
</code></pre><p><strong>Resolution</strong>:</p><pre><code class="language-bash">certbot renew --force-renewal
|
|
1396
|
+
systemctl reload nginx
|
|
1397
|
+
</code></pre><h2 id="emergency-procedures">Emergency Procedures</h2><h3 id="complete-service-outage">Complete Service Outage</h3><ol><li>Check if Nginx is running: <code>systemctl status nginx</code></li><li>Attempt restart: <code>systemctl restart nginx</code></li><li>If fails, check configuration: <code>nginx -t</code></li><li>Restore from backup if config corrupted</li><li>Failover to backup LB if necessary</li><li>Notify stakeholders</li></ol><h3 id="ddos-attack">DDoS Attack</h3><ol><li>Identify attack pattern in logs</li><li>Block offending IPs: <code>./block-ip.sh <IP></code></li><li>Enable stricter rate limits</li><li>Contact ISP for upstream filtering</li><li>Enable DDoS protection service (Cloudflare)</li></ol><h2 id="maintenance-windows">Maintenance Windows</h2><ul><li>Standard maintenance: Sundays 02:00-04:00 UTC</li><li>Emergency maintenance: As needed with approval</li></ul><h2 id="escalation">Escalation</h2><ol><li>On-call engineer (PagerDuty)</li><li>DevOps Lead</li><li>VP Engineering</li></ol><pre><code>
|
|
1398
|
+
---
|
|
1399
|
+
|
|
1400
|
+
## **Tổng kết Khóa học**
|
|
1401
|
+
|
|
1402
|
+
Chúc mừng! Bạn đã hoàn thành toàn bộ 15 bài học comprehensive về Nginx! 🎉
|
|
1403
|
+
|
|
1404
|
+
### **Nội dung đã học:**
|
|
1405
|
+
|
|
1406
|
+
**Phần Foundation (Bài 1-5):**
|
|
1407
|
+
- ✅ Giới thiệu và cài đặt Nginx
|
|
1408
|
+
- ✅ Cấu hình cơ bản
|
|
1409
|
+
- ✅ Logging và monitoring
|
|
1410
|
+
- ✅ Reverse proxy
|
|
1411
|
+
- ✅ Load balancing
|
|
1412
|
+
|
|
1413
|
+
**Phần Intermediate (Bài 6-10):**
|
|
1414
|
+
- ✅ Caching strategies
|
|
1415
|
+
- ✅ SSL/TLS và HTTPS
|
|
1416
|
+
- ✅ Performance tuning
|
|
1417
|
+
- ✅ Security hardening
|
|
1418
|
+
- ✅ Rewrite và redirects
|
|
1419
|
+
|
|
1420
|
+
**Phần Advanced (Bài 11-15):**
|
|
1421
|
+
- ✅ Application stack integration
|
|
1422
|
+
- ✅ Monitoring và logging advanced
|
|
1423
|
+
- ✅ High availability
|
|
1424
|
+
- ✅ Microservices và service mesh
|
|
1425
|
+
- ✅ Production best practices
|
|
1426
|
+
|
|
1427
|
+
### **Bạn có thể:**
|
|
1428
|
+
|
|
1429
|
+
1. **Deploy production-ready Nginx servers**
|
|
1430
|
+
2. **Implement high-availability architectures**
|
|
1431
|
+
3. **Optimize performance và security**
|
|
1432
|
+
4. **Troubleshoot complex issues**
|
|
1433
|
+
5. **Manage microservices architectures**
|
|
1434
|
+
6. **Meet compliance requirements**
|
|
1435
|
+
7. **Monitor và maintain systems effectively**
|
|
1436
|
+
|
|
1437
|
+
### **Next Steps:**
|
|
1438
|
+
|
|
1439
|
+
1. **Practice**: Deploy Nginx trong lab environment
|
|
1440
|
+
2. **Experiment**: Test các configurations khác nhau
|
|
1441
|
+
3. **Read**: Official Nginx documentation
|
|
1442
|
+
4. **Contribute**: Share knowledge với community
|
|
1443
|
+
5. **Certify**: Consider Nginx certifications
|
|
1444
|
+
6. **Advance**: Explore Nginx Plus features
|
|
1445
|
+
|
|
1446
|
+
### **Resources:**
|
|
1447
|
+
|
|
1448
|
+
- **Official Docs**: https://nginx.org/en/docs/
|
|
1449
|
+
- **Community**: https://forum.nginx.org/
|
|
1450
|
+
- **GitHub**: https://github.com/nginx/nginx
|
|
1451
|
+
- **Blog**: https://www.nginx.com/blog/
|
|
1452
|
+
|
|
1453
|
+
Chúc bạn thành công trong việc deploy và manage Nginx! 🚀
|
|
1454
|
+
</code></pre>
|