parent
1158a040fa
commit
75c728d6bd
@ -0,0 +1,42 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
namespace App\Providers; |
||||||
|
|
||||||
|
use Illuminate\Support\Facades\Gate; |
||||||
|
use Laravel\Horizon\Horizon; |
||||||
|
use Laravel\Horizon\HorizonApplicationServiceProvider; |
||||||
|
|
||||||
|
class HorizonServiceProvider extends HorizonApplicationServiceProvider |
||||||
|
{ |
||||||
|
/** |
||||||
|
* Bootstrap any application services. |
||||||
|
* |
||||||
|
* @return void |
||||||
|
*/ |
||||||
|
public function boot() |
||||||
|
{ |
||||||
|
parent::boot(); |
||||||
|
|
||||||
|
// Horizon::routeSmsNotificationsTo('15556667777'); |
||||||
|
// Horizon::routeMailNotificationsTo('example@example.com'); |
||||||
|
// Horizon::routeSlackNotificationsTo('slack-webhook-url', '#channel'); |
||||||
|
|
||||||
|
// Horizon::night(); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Register the Horizon gate. |
||||||
|
* |
||||||
|
* This gate determines who can access Horizon in non-local environments. |
||||||
|
* |
||||||
|
* @return void |
||||||
|
*/ |
||||||
|
protected function gate() |
||||||
|
{ |
||||||
|
Gate::define('viewHorizon', function ($user) { |
||||||
|
return in_array($user->email, [ |
||||||
|
// |
||||||
|
]); |
||||||
|
}); |
||||||
|
} |
||||||
|
} |
||||||
@ -0,0 +1,197 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
use Illuminate\Support\Str; |
||||||
|
|
||||||
|
return [ |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Horizon Domain |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| This is the subdomain where Horizon will be accessible from. If this |
||||||
|
| setting is null, Horizon will reside under the same domain as the |
||||||
|
| application. Otherwise, this value will serve as the subdomain. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'domain' => env('HORIZON_DOMAIN'), |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Horizon Path |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| This is the URI path where Horizon will be accessible from. Feel free |
||||||
|
| to change this path to anything you like. Note that the URI will not |
||||||
|
| affect the paths of its internal API that aren't exposed to users. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'path' => env('HORIZON_PATH', 'horizon'), |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Horizon Redis Connection |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| This is the name of the Redis connection where Horizon will store the |
||||||
|
| meta information required for it to function. It includes the list |
||||||
|
| of supervisors, failed jobs, job metrics, and other information. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'use' => 'default', |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Horizon Redis Prefix |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| This prefix will be used when storing all Horizon data in Redis. You |
||||||
|
| may modify the prefix when you are running multiple installations |
||||||
|
| of Horizon on the same server so that they don't have problems. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'prefix' => env( |
||||||
|
'HORIZON_PREFIX', |
||||||
|
Str::slug(env('APP_NAME', 'laravel'), '_').'_horizon:' |
||||||
|
), |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Horizon Route Middleware |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| These middleware will get attached onto each Horizon route, giving you |
||||||
|
| the chance to add your own middleware to this list or change any of |
||||||
|
| the existing middleware. Or, you can simply stick with this list. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'middleware' => ['web'], |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Queue Wait Time Thresholds |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| This option allows you to configure when the LongWaitDetected event |
||||||
|
| will be fired. Every connection / queue combination may have its |
||||||
|
| own, unique threshold (in seconds) before this event is fired. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'waits' => [ |
||||||
|
'redis:default' => 60, |
||||||
|
], |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Job Trimming Times |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| Here you can configure for how long (in minutes) you desire Horizon to |
||||||
|
| persist the recent and failed jobs. Typically, recent jobs are kept |
||||||
|
| for one hour while all failed jobs are stored for an entire week. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'trim' => [ |
||||||
|
'recent' => 60, |
||||||
|
'pending' => 60, |
||||||
|
'completed' => 60, |
||||||
|
'recent_failed' => 10080, |
||||||
|
'failed' => 10080, |
||||||
|
'monitored' => 10080, |
||||||
|
], |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Metrics |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| Here you can configure how many snapshots should be kept to display in |
||||||
|
| the metrics graph. This will get used in combination with Horizon's |
||||||
|
| `horizon:snapshot` schedule to define how long to retain metrics. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'metrics' => [ |
||||||
|
'trim_snapshots' => [ |
||||||
|
'job' => 24, |
||||||
|
'queue' => 24, |
||||||
|
], |
||||||
|
], |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Fast Termination |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| When this option is enabled, Horizon's "terminate" command will not |
||||||
|
| wait on all of the workers to terminate unless the --wait option |
||||||
|
| is provided. Fast termination can shorten deployment delay by |
||||||
|
| allowing a new instance of Horizon to start while the last |
||||||
|
| instance will continue to terminate each of its workers. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'fast_termination' => false, |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Memory Limit (MB) |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| This value describes the maximum amount of memory the Horizon master |
||||||
|
| supervisor may consume before it is terminated and restarted. For |
||||||
|
| configuring these limits on your workers, see the next section. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'memory_limit' => 64, |
||||||
|
|
||||||
|
/* |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| Queue Worker Configuration |
||||||
|
|-------------------------------------------------------------------------- |
||||||
|
| |
||||||
|
| Here you may define the queue worker settings used by your application |
||||||
|
| in all environments. These supervisors and settings handle all your |
||||||
|
| queued jobs and will be provisioned by Horizon during deployment. |
||||||
|
| |
||||||
|
*/ |
||||||
|
|
||||||
|
'defaults' => [ |
||||||
|
'supervisor-1' => [ |
||||||
|
'connection' => 'redis', |
||||||
|
'queue' => ['default'], |
||||||
|
'balance' => 'auto', |
||||||
|
'maxProcesses' => 1, |
||||||
|
'maxTime' => 0, |
||||||
|
'maxJobs' => 0, |
||||||
|
'memory' => 128, |
||||||
|
'tries' => 1, |
||||||
|
'timeout' => 60, |
||||||
|
'nice' => 0, |
||||||
|
], |
||||||
|
], |
||||||
|
|
||||||
|
'environments' => [ |
||||||
|
'production' => [ |
||||||
|
'supervisor-1' => [ |
||||||
|
'maxProcesses' => 10, |
||||||
|
'balanceMaxShift' => 1, |
||||||
|
'balanceCooldown' => 3, |
||||||
|
], |
||||||
|
], |
||||||
|
|
||||||
|
'local' => [ |
||||||
|
'supervisor-1' => [ |
||||||
|
'maxProcesses' => 3, |
||||||
|
], |
||||||
|
], |
||||||
|
], |
||||||
|
]; |
||||||
@ -1,32 +0,0 @@ |
|||||||
<?php |
|
||||||
|
|
||||||
use Illuminate\Database\Migrations\Migration; |
|
||||||
use Illuminate\Database\Schema\Blueprint; |
|
||||||
use Illuminate\Support\Facades\Schema; |
|
||||||
|
|
||||||
return new class extends Migration |
|
||||||
{ |
|
||||||
/** |
|
||||||
* Run the migrations. |
|
||||||
* |
|
||||||
* @return void |
|
||||||
*/ |
|
||||||
public function up() |
|
||||||
{ |
|
||||||
Schema::create('password_resets', function (Blueprint $table) { |
|
||||||
$table->string('email')->index(); |
|
||||||
$table->string('token'); |
|
||||||
$table->timestamp('created_at')->nullable(); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
/** |
|
||||||
* Reverse the migrations. |
|
||||||
* |
|
||||||
* @return void |
|
||||||
*/ |
|
||||||
public function down() |
|
||||||
{ |
|
||||||
Schema::dropIfExists('password_resets'); |
|
||||||
} |
|
||||||
}; |
|
||||||
@ -1,37 +0,0 @@ |
|||||||
<?php |
|
||||||
|
|
||||||
use Illuminate\Database\Migrations\Migration; |
|
||||||
use Illuminate\Database\Schema\Blueprint; |
|
||||||
use Illuminate\Support\Facades\Schema; |
|
||||||
|
|
||||||
return new class extends Migration |
|
||||||
{ |
|
||||||
/** |
|
||||||
* Run the migrations. |
|
||||||
* |
|
||||||
* @return void |
|
||||||
*/ |
|
||||||
public function up() |
|
||||||
{ |
|
||||||
Schema::create('personal_access_tokens', function (Blueprint $table) { |
|
||||||
$table->id(); |
|
||||||
$table->morphs('tokenable'); |
|
||||||
$table->string('name'); |
|
||||||
$table->string('token', 64)->unique(); |
|
||||||
$table->text('abilities')->nullable(); |
|
||||||
$table->timestamp('last_used_at')->nullable(); |
|
||||||
$table->timestamp('expires_at')->nullable(); |
|
||||||
$table->timestamps(); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
/** |
|
||||||
* Reverse the migrations. |
|
||||||
* |
|
||||||
* @return void |
|
||||||
*/ |
|
||||||
public function down() |
|
||||||
{ |
|
||||||
Schema::dropIfExists('personal_access_tokens'); |
|
||||||
} |
|
||||||
}; |
|
||||||
Loading…
Reference in new issue