+7

Code Laravel đã lâu, nhưng có thể bạn chưa biết về Telescope!

Lời mở đầu

  • Xin chào các bạn, đã lâu rồi mình mới tiếp tục series Những chức năng bạn có thể cần trong một project Laravel này. Và hôm nay bài viết này sẽ không đề cập đến một chức năng cho người sử dụng website mà là một công cụ hỗ trợ cho chính những developer chúng ta để công việc debug trở nên dễ dàng hơn đôi chút, còn fix bug có dễ hơn không thì mình không dám đảm bảo nha 😆😆😆😆😆😆

  • Nói đến đây thì có thể nhiều người sẽ nghĩ đến Laravel Debugbar, tuy nhiên trong bài viết này mình sẽ giới thiệu đến các bạn một công cụ "mới mẻ" hơn khá nhiều.

Nội dung

Giới thiệu về Telescope

Theo như định nghĩa trên trang github của Telescope thì đây là một công cụ hỗ trợ debug trong framework Laravel. Telescope cung cấp những thông tin như queued jobs, schedule, database queries, ... để giúp bạn có thể debug dễ dàng hơn trên môi trường local.

Laravel Telescope is an elegant debug assistant for the Laravel framework. Telescope provides insight into the requests coming into your application, exceptions, log entries, database queries, queued jobs, mail, notifications, cache operations, scheduled tasks, variable dumps and more. Telescope makes a wonderful companion to your local Laravel development environment.

Cài đặt Telescope

  • Để cài đặt được Telescope, yêu cầu tối thiểu là bạn phải sử dụng phiên bản Laravel 5.7.7 trở lên, đơn giản là vì Telescope ra đời từ phiên bản Laravel 5.7, nếu các bạn thử truy cập đường link https://laravel.com/docs/x.y/telescope với x.y < 5.7 thì sẽ thu được kết quả như thế này:

  • Khi đã thoả mãn requirement, bạn sẽ tiền hành cài đặt package thông qua composer:
    • B1: cài đặt package thông qua composer

      composer require "laravel/telescope":"~1.0"
      #nếu bạn chỉ muốn sử dụng cho môi trường local của bản thân thì chỉ cần thêm option --dev vào câu lệnh
      
    • B2: chạy 2 câu lệnh để publish assets và chạy migration

      php artisan telescope:install         #publish assets lần đầu tiên
      Publishing Telescope Service Provider...
      Publishing Telescope Assets...
      Publishing Telescope Configuration...
      Telescope scaffolding installed successfully.
      
      php artisan telescope:publish         #re-publish assets mỗi khi update lại telescope
      
      php artisan migrate         #migrate database
      Migrating: 2018_08_08_100000_create_telescope_entries_table
      Migrated:  2018_08_08_100000_create_telescope_entries_table
      
    • B3: cũng giống như các công cụ debug khác thường không được cài đặt trên môi trường production, vì vậy, để cài đặt telescope cho môi trường local, ngoài việc thêm option --dev vào câu lệnh thì sẽ phải xoá TelescopeServiceProvider khỏi config/app.php và thêm vào App\Providers\AppServiceProvider đoạn code sau:

      /**
      * Register any application services.
      *
      * @return void
      */
      public function register()
      {
         if ($this->app->environment('local')) {
             $this->app->register(\Laravel\Telescope\TelescopeServiceProvider::class);
             $this->app->register(TelescopeServiceProvider::class);
         }
      }
      
    • B4: thiết lập cấu hình cho telescope trong file config/telescope.php. Trong file config này có chứa những thông tin như:

      • domain: 'domain' => env('TELESCOPE_DOMAIN', null)
      • enabled/disabled: 'enabled' => env('TELESCOPE_ENABLED', true)
      • middleware: khai báo những middleware được sử dụng cho các telescope route.
      • watchers: khai báo những watcher được sử dụng để thu thập dữ liệu khi có một request hoặc một command được thực thi (VD: QueryWatcher. CommandWatcher, JobWatcher, LogWatcher, ...)

Một số chức năng đáng chú ý

Hiển thị avatar của user

  • Với tính năng này, trong màn hình dashboard của telescope sẽ hiển thị avatar của user đang được xác thực để thực thi các request hoặc command. Với thiết lập mặc định thì sẽ sử dụng dịch vụ Gravatar web service để tạo avatar, tuy nhiên bạn vẫn có thể tuỳ chỉnh trong App\Providers\TelescopeServiceProvider giống như bên dưới:
    use App\Models\User;
    use Laravel\Telescope\Telescope;
    
    /**
     * Register any application services.
     *
     * @return void
     */
    public function register()
    {
        // ...
    
        Telescope::avatar(function ($id, $email) {
            return '/avatars/'.User::find($id)->avatar_path;
        });
    }
    

Requests

  • Mỗi khi có một request được gửi lên thì sẽ được lưu lại thông tin giống như hình bên dưới. Như các bạn có thể thấy thì những thông tin của request gồm có phương thức request (GET/POST/...), route, HTTP response status codethời gian gửi request.

  • Bạn có thể click vào request để có thể xem thông tin chi tiết của request đó (Headers/Session/Response/Logs/Queries/...), giống như hình ảnh bên dưới.

Command

  • Đây là phần lưu lại thông tin của mỗi command giống như request, cũng bao gồm 2 màn hình danh sách command và màn hình thông tin chi tiết của command.

danh sách command

thông tin chi tiết của command

  • Trong màn hình thông tin chi tiết, bạn có thể xem được danh sách các câu truy vấn (queries) được thực thi bên trong command.
    • Thông tin thời gian thực thi (duration) để biết được câu truy vấn của bạn nhanh hay chậm, từ đó có thể điều chỉnh câu truy vấn để tối ưu performance cho command của bạn/
    • Ngoài thời gian thực thi nhanh hay chậm thì bạn có thể xem được có bao nhiêu câu truy vấn bị lặp lại (duplicate query) làm chậm tốc độ truy vấn để có thể loại bỏ.

Jobs

  • Trong màn hình danh sách các jobs đã và đang thực thi, bạn có thể nắm được thông tin tên job, connection (sync), status, thời điểm chạy job.

danh sách các jobs (thông tin gần giống vs màn request)

thông tin chi tiết của job

  • Màn hình chi tiết bao gồm các thông tin như sau:
    • status: trạng thái của job (pending/processed/failed)
    • connection: sync
    • tries: số lần chạy job
    • timeout: thời gian tối đa mà command có thể chạy, tính bằng giây (s)
    • data: job/delay/queue/...

Ngoài ra còn rất nhiều chức năng khác rất hữu dụng, bạn có thể xem chi tiết bằng cách click vào danh sách sidebar của màn hình dashboard (Logs/Queries/Exceptions/Cache/...)

Tổng kết

  • Hy vọng bài viết này đã cung cấp cho các bạn một công cụ hữu ích để có thể làm cho cuộc đời của các bạn developer bớt khổ hơn trong công cuộc debug cũng như là cải thiện một phần performance của trang web.
  • Nếu thấy bài viết này hữu ích, hãy upvote bài viết ủng hộ cho mình và clip bài viết lại để có thể xem lại sau này nhé.
  • Còn nếu như bài viết có vấn đề gì chưa tốt, các bạn hãy comment xuống dưới góp ý giúp mình để có thể cải thiện khả năng trình bày cũng như kiến thức một cách nhanh chóng và kịp thời nhất nhé.

Tài liệu tham khảo


All rights reserved

Bình luận

Đăng nhập để bình luận
Avatar
@phhuy38
thg 1 20, 2021 6:41 SA

Vậy trên môi trường production thì cần cài gì để debug bạn nhỉ?

Avatar
@vuongthai95
thg 1 21, 2021 1:03 SA

Do trong quá trình debug có thể sẽ trả về một số thông tin "nhạy cảm" mà user không cần/không được biết nên thường sẽ không bật debug cho môi trường production (bạn có thể tham khảo bài viết này https://viblo.asia/p/chi-mot-buoi-chieu-toi-da-chiem-quyen-dieu-khien-server-cua-8-website-nhu-the-nao-Do7542neZM6)

Thường thì 1 dự án sẽ có 3 môi trường: local (để dev), staging (test trước khi đưa lên production) và production giống nhau nhất có thể, khi có lỗi trên production thì bạn sẽ tái hiện và debug trên môi trường local thôi

Avatar
+7
Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí