|
@@ -9,6 +9,7 @@ use Illuminate\Contracts\Queue\ShouldQueue;
|
|
|
use Illuminate\Foundation\Bus\Dispatchable;
|
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
|
use Illuminate\Queue\SerializesModels;
|
|
|
+use Illuminate\Support\Facades\DB;
|
|
|
|
|
|
class TrafficFetchJob implements ShouldQueue
|
|
|
{
|
|
@@ -44,13 +45,18 @@ class TrafficFetchJob implements ShouldQueue
|
|
|
*/
|
|
|
public function handle()
|
|
|
{
|
|
|
- $user = User::lockForUpdate()->find($this->userId);
|
|
|
+ $user = User::find($this->userId);
|
|
|
if (!$user) return;
|
|
|
- $user->t = time();
|
|
|
- $user->u = $user->u + $this->u;
|
|
|
- $user->d = $user->d + $this->d;
|
|
|
- if (!$user->save()) throw new \Exception('流量更新失败');
|
|
|
+ try {
|
|
|
+ $user->update([
|
|
|
+ 't' => time(),
|
|
|
+ 'u' => DB::raw("u+{$this->u}"),
|
|
|
+ 'd' => DB::raw("d+{$this->d}")
|
|
|
+ ]);
|
|
|
+ } catch (\Exception $e) {
|
|
|
+ throw new \Exception('流量更新失败');
|
|
|
+ }
|
|
|
$mailService = new MailService();
|
|
|
- $mailService->remindTraffic($user);
|
|
|
+ $mailService->remindTraffic($user->first());
|
|
|
}
|
|
|
}
|