Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Kubernetes with Laravel

Kubernetes with Laravel

Bobby Bouwmann

December 11, 2019
Tweet

More Decks by Bobby Bouwmann

Other Decks in Programming

Transcript

  1. Kubernetes with Laravel
    Kubernetes with Laravel

    View Slide

  2. @bobbybouwmann
    Kubernetes with Laravel

    View Slide

  3. Kubernetes with Laravel

    View Slide

  4. Kubernetes with Laravel

    View Slide

  5. Agenda
    • What is kubernetes
    • Laravel with Kubernetes
    • Kubernetes vs Larvel Vapor
    Kubernetes with Laravel

    View Slide

  6. What is kubernetes?
    • Orchestra*on pla0orm for containers
    • Is compatable with Docker
    • Manages deployments and scaling
    Kubernetes with Laravel

    View Slide

  7. Kubernetes with Laravel

    View Slide

  8. kubectl get pods -o wide
    NAME READY STATUS AGE IP NODE
    horizon-794474c567-5mxwm 1/1 Running 8d 172.31.17.141 server01.eu-central-1
    app-57c65f4d5b-9jbjc 1/1 Running 8d 172.31.21.72 server01.eu-central-1
    app-57c65f4d5b-hlz25 1/1 Running 8d 172.31.9.186 server02.eu-central-1
    app-57c65f4d5b-tzbb8 1/1 Running 8d 172.31.26.106 server02.eu-central-1
    Kubernetes with Laravel

    View Slide

  9. NAME READY STATUS RESTARTS AGE
    app-594f6cfd8b-gl84s 1/1 Running 0 3d
    app-594f6cfd8b-8623b 1/1 Running 0 3d
    Kubernetes with Laravel

    View Slide

  10. kubectl apply -f docker/kube/prod.yml
    NAME READY STATUS RESTARTS AGE
    app-vb345b238p-4mnz7 0/1 Terminating 0 3d
    app-vb345b238p-8623b 1/1 Running 0 3d
    app-7764bd5f8d-k2k55 0/1 Init:0/1 0 7s
    Kubernetes with Laravel

    View Slide

  11. NAME READY STATUS RESTARTS AGE
    app-594f6cfd8b-gl84s 1/1 Running 0 3d
    app-7764bd5f8d-k2k55 0/1 Init:0/1 0 7s
    Kubernetes with Laravel

    View Slide

  12. NAME READY STATUS RESTARTS AGE
    app-7764bd5f8d-k2k55 1/1 Running 0 27s
    app-7764bd5f8d-39dd7 1/1 Running 0 3s
    Kubernetes with Laravel

    View Slide

  13. NAME READY STATUS RESTARTS AGE
    app-7764bd5f8d-gl84s 1/1 Running 0 3d
    app-59b6f55476-nx65z 0/1 CrashLoopBackOff 4 35s
    Kubernetes with Laravel

    View Slide

  14. NAME READY STATUS RESTARTS AGE
    cron-594f6cfd8b-5j46r 0/1 ContainerCreating 0 1s
    app-7764bd5f8d-gl84s 1/1 Running 0 2d
    app-7764bd5f8d-j234j 1/1 Running 0 2d
    Kubernetes with Laravel

    View Slide

  15. NAME READY STATUS RESTARTS AGE
    cron-594f6cfd8b-5j46r 0/1 Completed 0 12s
    app-7764bd5f8d-gl84s 1/1 Running 0 2d
    app-7764bd5f8d-j234j 1/1 Running 0 2d
    Kubernetes with Laravel

    View Slide

  16. Laravel with Kubernetes
    Kubernetes with Laravel

    View Slide

  17. Storage
    • Database
    • Storage
    • Logging
    • Excep3on Logging
    • Sessions
    • Queues
    Kubernetes with Laravel

    View Slide

  18. Database
    // .env
    DB_CONNECTION=mysql
    DB_HOST=prod.hbwehrkblh.eu-central-1.rds.amazonaws.com
    DB_PORT=3306
    DB_DATABASE=app
    DB_USERNAME=app
    DB_PASSWORD=123KDjh1233DH*(gh2{34jk]h23\h4)
    Kubernetes with Laravel

    View Slide

  19. Storage
    // config/filesystems.php
    'disks' => [
    's3' => [
    'driver' => 's3',
    'key' => env('AWS_ACCESS_KEY_ID'),
    'secret' => env('AWS_SECRET_ACCESS_KEY'),
    'region' => env('AWS_DEFAULT_REGION'),
    'bucket' => env('AWS_BUCKET'),
    'url' => env('AWS_URL'),
    ],
    ],
    Kubernetes with Laravel

    View Slide

  20. Logging
    // config/logging.php
    'channnels' => [
    'papertrail' => [
    'driver' => 'monolog',
    'level' => 'debug',
    'handler' => SyslogUdpHandler::class,
    'handler_with' => [
    'host' => env('PAPERTRAIL_URL'),
    'port' => env('PAPERTRAIL_PORT'),
    ],
    ],
    ],
    Kubernetes with Laravel

    View Slide

  21. // config/logging.php
    'channels' => [
    'stderr' => [
    'driver' => 'monolog',
    'handler' => StreamHandler::class,
    'formatter' => env('LOG_STDERR_FORMATTER'),
    'with' => [
    'stream' => 'php://stderr',
    ],
    ],
    ],
    Kubernetes with Laravel

    View Slide

  22. Excep&on logging
    // config/logging.php
    [
    'default' => env('LOG_CHANNEL', 'stack'),
    'channels' => [
    'stack' => [
    'driver' => 'stack',
    'channels' => ['daily', 'flare'],
    'ignore_exceptions' => false,
    ],
    ],
    ]
    Kubernetes with Laravel

    View Slide

  23. Kubernetes with Laravel

    View Slide

  24. Excep&on logging
    // .env
    SENTRY_LARAVEL_DSN=https://[email protected]/8499832
    Kubernetes with Laravel

    View Slide

  25. Kubernetes with Laravel

    View Slide

  26. Sessions
    // .env
    SESSION_DRIVER=database
    SESSION_LIFETIME=120
    Kubernetes with Laravel

    View Slide

  27. Queues
    QUEUE_CONNECTION=sync
    REDIS_HOST=redis
    REDIS_PASSWORD=null
    REDIS_PORT=6379
    Kubernetes with Laravel

    View Slide

  28. Queues
    QUEUE_CONNECTION=sync
    REDIS_HOST=redis
    REDIS_PASSWORD=null
    REDIS_PORT=6379
    Kubernetes with Laravel

    View Slide

  29. Kubernetes with Laravel

    View Slide

  30. Golden rules
    • Persistent storage is always external
    • Container monitoring
    • Keep containers small
    Kubernetes with Laravel

    View Slide

  31. Kubernetes vs Laravel Vapor
    Kubernetes with Laravel

    View Slide

  32. Kubernetes with Laravel

    View Slide

  33. Kubernetes with Laravel

    View Slide

  34. h"p:/
    /bit.ly/laravel-giveaway
    Kubernetes with Laravel

    View Slide

  35. Kubernetes with Laravel
    - Any ques*ons? -
    Kubernetes with Laravel

    View Slide