laravel mysql驱动_Laravel 如何同时使用不同数据库驱动

queue配置

首先说明一下我之前的项目中如何使用queue的。

我们现在的项目都是用的symfony,老一点的项目用的symfony1poser/vendor/bin 加入到环境变量中。

source ~/.bash_profile 就可以直接在命令行中使用laravel了。试一下。

laravel -V 能够看到下面的,就代表成功了。

Laravel Installer version 1.2.1 2、创建项目。

laravel new guagua 3、配置redis和queue。

4、创建controller,

php artisan make:controller DefaultController 在controller的action中push100个queue的任务。

for($i = 0; $i < 100; $i ++) { Queue::push(new SendEmail("ssss".$i)); } 5、创建queue的Command

php artisan make:command SendEmail --queued 修改app/Commands/SendEmail.php,添加一个私有变量。

protected $msg; 同时修改构造函数。

public function __construct($msg) { $this->msg = $msg; } 再修改的handle方法

public function handle() { sleep(4); echo $this->msg."\t".date("Y-m-d H:i:s")."\n"; $this->delete(); } 6、修改routes

Route::get('/', [ 'as' => 'index', 'uses' => 'DefaultController@index' ]); 7、监听queue

php artisan queue:listen 为了验证多任务处理,我们同时开三个窗口运行同样的命令。

8、用laravel内建的server启动服务

php artisan serve --port 8080 打开浏览器,访问localhost:8080/页面。当然也可以用nginx,apache之类的。但是需要各种配置,还是内建的使用方便。

在控制台就能看到各个queue执行的情况了,如下图。可以看到100个任务被三个work平分了。

到此,基本达到了我想要的效果。验证了laravel可以简单实现queue,并且可以多任务处理。

make command生成的代码中use App\Commands\Command ,但是运行时提示没有这个文件。 解决办法,修改为 use Illuminate\Console\Command; 不知道为什么会出现这个低级问题,难道是我mac系统问题,还是我的人品问题。

在controller的action中push队列的时候,没有异步执行,还是在action的脚本中执行的。 发现是配置问题,原来不仅仅要修改config中的queue.php,还要修改.evn中相关配置。 虽然问题解决了,但是还是觉得蛋疼,不能理解。还需要在学习学习laravel。

异步队列使用方法

1.配置

关于队列的定义,这里就不作介绍了。我们要使用异步队列就有两个关键:

(1)存储队列的地方

(2)执行任务的服务

打开 config/queue.php ,这是Laravel5关于队列的配置文件。首先我们可以通过 default 参数指定默认队列驱动,默认配置是 sync , 这是同步队列,我们要做异步队列首先就要改变这里。假设我们用 database 作为驱动,队列任务将会存放在数据库中,而我们后面会另外启动一个后台服务来处理队列任务,这就是异步方式了。

'default' => 'database' 修改完配置后,我们需要创建一个表来存放队列任务,Laravel5已经在自带artisan命令中内置了一个指令用来生成数据迁移,只需要两条命令即可,当然你得实现配置好数据库连接。

php artisan queue:table php artisan migrate 这样就自动在数据库中创建了 jobs 表。

2.启动队列监听服务

通过下面这条指令启动队列监听服务,它会自动处理 jobs 表中的队列任务:

php artisan queue:listen 在linux中,如果想让它在后台执行,可以这样:

nohup php artisan queue:listen & 3.添加队列任务

关于队列任务的添加,手册里说的比较详细,这里就简单举个例子吧。

首先,通过artisan创建一个队列命令:

php artisan make:command SendEmail --queued 这样会生成 app/Commands/SendEmail.php 这个类文件,这个类会被标识为队列命令,你可以在 handle 方法中写自己的业务逻辑。

在控制器中,可以简单通过 Bus::dispatch 分发任务:

Bus::dispatch(new \App\Commands\SendEmail()); 你会发现任务不会立即执行,而是被放到 jobs 表中,由队列监听服务处理。

更详细的用法建议参考 command bus 和 queue 相关的手册章节。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Laravel 连接 MySQL 数据库需要进行以下配置: 1. 打开 `.env` 文件,设置数据库连接相关的环境变量,例如: ``` DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=your_database_name DB_USERNAME=your_database_username DB_PASSWORD=your_database_password ``` 2. 打开 `config/database.php` 文件,确认数据库配置是否正确,例如: ``` 'mysql' => [ 'driver' => 'mysql', 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'strict' => true, 'engine' => null, ], ``` 3. 如果你使用的是 MySQL 8.0 版本以上,需要修改 `config/database.php` 文件的 `mysql` 配置,将 `'strict' => true` 改为 `'strict' => false`,否则会出现严格模式错误。 4. 如果你的 MySQL 服务器不在本地,需要确保你可以通过网络访问到 MySQL 服务器。你可以通过 telnet 命令测试 MySQL 服务器是否可用,例如:`telnet ip_address port`。 5. 最后,你可以在 Laravel 项目测试数据库连接是否成功,例如: ``` Route::get('/test-database-connection', function() { try { DB::connection()->getPdo(); echo "Database connection is OK!"; } catch (\Exception $e) { die("Could not connect to the database. Please check your configuration. error:" . $e ); } }); ``` 如果运行该路由,输出 `Database connection is OK!`,则说明数据库连接成功。 ### 回答2: Laravel是一个流行的PHP框架,它提供了许多方便的功能和易于使用的工具,用于构建高效的Web应用程序。当我们使用Laravel时,需要连接数据库,一种常见的数据库选择是MySQL。 要在Laravel连接MySQL数据库,我们需要进行一些配置步骤。首先,我们需要在项目的.env文件设置数据库连接的相关配置。这可以通过在.env文件设置DB_CONNECTION、DB_HOST、DB_PORT、DB_DATABASE、DB_USERNAME和DB_PASSWORD来完成。其,DB_CONNECTION设置为mysql,DB_HOST设置为数据库的主机地址,DB_PORT设置为数据库的端口号,DB_DATABASE设置为要连接的数据库的名称,DB_USERNAME和DB_PASSWORD分别设置为数据库的用户名和密码。 配置完成后,我们可以在Laravel应用使用数据库连接。通过Laravel自带的数据库查询构建器或Eloquent ORM,我们可以执行各种数据库操作,如插入、更新、删除和查询数据。 例如,如果要查询users表的所有记录,我们可以使用以下代码: ``` $users = DB::table('users')->get(); ``` 这将返回一个包含所有用户记录的数组。 另外,我们还可以使用Eloquent ORM进行更高级的数据库操作。首先,我们需要创建一个与数据库表对应的模型。例如,如果要操作users表,我们可以创建一个User模型,然后定义表名等相关信息。然后,我们就可以使用模型类来执行各种数据库操作,如创建、保存、更新和删除记录。 总之,通过配置数据库连接信息,并使用Laravel提供的数据库查询构建器或Eloquent ORM,我们可以方便地在Laravel连接和操作MySQL数据库。 ### 回答3: Laravel是一个流行的PHP框架,提供了许多便捷的功能和工具来简化开发过程。在Laravel,连接MySQL数据库非常简单。 首先,确保已经安装了MySQL数据库并设置好了用户名和密码。然后,在Laravel的配置文件.env,找到以下几个配置项: DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=homestead DB_USERNAME=root DB_PASSWORD= 这些配置项用于指定数据库的链接信息,其的参数根据具体的情况进行修改。 - DB_CONNECTION 指定数据库驱动,这里设为mysql。 - DB_HOST指定数据库的主机地址,默认是127.0.0.1,本地地址。 - DB_PORT指定数据库的端口,默认是3306。 - DB_DATABASE指定要连接的数据库名称,这里设为homestead,可以根据实际情况修改。 - DB_USERNAME和DB_PASSWORD指定连接数据库的用户名和密码,默认为空。 完成以上配置后,Laravel将自动使用这些配置信息来连接MySQL数据库。 在Laravel,可以使用数据库查询构建器来执行各种查询操作。查询构建器提供了一种在PHP代码流畅、直观地编写SQL查询的方式。以下是一个简单的例子,演示了如何使用Laravel进行数据库查询: $users = DB::table('users')->where('name', 'John')->first(); 上述代码将从users表选择名字为John的第一条记录,并将结果存储在$users变量使用DB::table()方法指定表名,然后使用where()方法来添加查询条件。 以上就是使用Laravel连接MySQL数据库的简单介绍。Laravel提供了更多高级的数据库操作功能,如ORM(对象关系映射),以及查询构建器支持的各种查询方法。通过合理地利用这些功能,可以更加方便地处理和管理数据库数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值