- vừa được xem lúc

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

0 0 101

Người đăng: Vương Minh Thái

Theo Viblo Asia

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

Bình luận

Bài viết tương tự

- vừa được xem lúc

Tìm hiểu về Resource Controller trong Laravel

Giới thiệu. Trong laravel, việc sử dụng các route post, get, group để gọi đến 1 action của Controller đã là quá quen đối với các bạn sử dụng framework này.

0 0 425

- vừa được xem lúc

Phân quyền đơn giản với package Laravel permission

Như các bạn đã biết, phân quyền trong một ứng dụng là một phần không thể thiếu trong việc phát triển phần mềm, dù đó là ứng dụng web hay là mobile. Vậy nên, hôm nay mình sẽ giới thiệu một package có thể giúp các bạn phân quyền nhanh và đơn giản trong một website được viết bằng PHP với framework là L

0 0 512

- vừa được xem lúc

Sử dụng Swagger để xây dựng API documentation

Giới thiệu về Swagger. RESTful API là một tiêu chuẩn dùng trong việc thiết kế API cho các ứng dụng web (thiết kế Web services) để tiện cho việc quản lý các resource.

0 0 1k

- vừa được xem lúc

Ví dụ CRUD với Laravel và Vuejs.

1. Cài đặt Laravel. composer create-project --prefer-dist laravel/laravel vuelaravelcrud. .

0 0 163

- vừa được xem lúc

Một số tips khi dùng laravel (Part 1)

1. Show database query in raw SQL format. DB::enableQueryLog(); // Bật tính năng query logging. DB::table('users')->get(); // Chạy truy vấn bạn muốn ghi log.

0 0 90

- vừa được xem lúc

Inertiajs - Xây dựng Single Page App không cần API

Tiêu đề là mình lấy từ trang chủ của https://inertiajs.com/ chứ không phải mình tự nghĩ ra đâu nhé :v. Lâu lâu rồi chưa động tới Laravel (dự án cuối cùng mình code là ở ver 5.8), thế nên một ngày đẹp trời lượn vào đọc docs ver 8.

0 0 242