PHP的Laravel框架結(jié)合MySQL與Redis數(shù)據(jù)庫的使用部署
相對于熟讀官方文檔,更重要的是要把框架環(huán)境搭起來。
零、環(huán)境介紹
- 操作系統(tǒng):centOS
- 數(shù)據(jù)庫: mysql 5.6 (阿里云RDS)
- PHP 5.4.4 (>=5.4即可)
- Laravel 5.0
一、安裝LNMP
在安裝Laravel之前,需要把Linux + Nginx + Mysql + Php的環(huán)境搭建好。具體的搭建步驟這里就不再詳述了。
P.S.
- Linux阿里云已經(jīng)自帶了,本文使用的是centOS 6.5 64位的ECS
- 關(guān)于Nginx和Apache的選擇看自己喜好,本文使用的是反向代理能手Nginx
- 是否安裝Mysql也要看自己的情況,例如你使用阿里云的RDS,那就沒必要安裝了
二、安裝Composer
composer是用來管理PHP包依賴的工具,Laravel正使用此工具進來依賴管理。有兩種安裝方式
局部安裝
全局安裝,即在系統(tǒng)任意目錄下可使用。本文只介紹此種安裝方法。官方安裝文檔
分別執(zhí)行以下兩條命令
curl -sS https://getcomposer.org/installer | php mv composer.phar /usr/local/bin/composer
安裝完成,使用以下命令看是否安裝成功
composer -V
出現(xiàn)版本號,即說明安裝成功
三、安裝Laravel
按照Laravel的官方文檔說明即可,建議使用【通過Laravel安裝工具】,沒什么坑,這里略過
提示:由于Laravel還依賴于一些的PHP擴展,所以使用yum安裝
sudo install yum php-mysql php-mcrypt php-mbstring php-tokenizer php-openssl
安裝完成后,在Nginx的配置文件(一般是/etc/nginx/conf.d/default.conf)最下方添加如下配置
location / {
try_files $uri $uri/ /index.php?$query_string;
}
來到你的laravel工程目錄下,看到storage和vendor文件夾,使用以下命令修改其文件讀寫權(quán)限,讓Nginx用戶能讀寫它
sudo chmod -R 766 storage sudo chmod -R 766 vendor
四、讓MVC跑起來!
在此之前,你應(yīng)該讀一下官方文檔 路由、控制器、數(shù)據(jù)庫使用基礎(chǔ)、Eloquent ORM
至此,可以開始coding,開發(fā)一個 MVC的demo了,此demo的功能是將數(shù)據(jù)庫表tbl_item從數(shù)據(jù)庫里讀出來,并以json格式響應(yīng)給瀏覽器。
假設(shè)你已經(jīng)通過laravel new demo來初始化你的web app。
- 數(shù)據(jù)庫里建庫(demo)、建表(tbl_item),(字段隨意定)
- 配置配置文件 config/database.php
- 直接操作數(shù)據(jù)庫,往tbl_item里插入一條數(shù)據(jù)
- 開始coding
demo/app/http/routes.php底部添加如下代碼:
Route::get('/item/{id}', 'ItemController@showItem');
demo/app/http/controllers/ 目錄新添文件 ItemController.php,代碼如下:
<?php namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Item as Item;
class ItemController extends Controller {
private $model;
public function __construct()
{
$this->model = new Item();
}
public function showItem($id)
{
$users = $this->model->fetchAll();
echo json_encode($users);
Log::info('獲取用戶列表,通過msyql');
}
}
demo/app/目錄下新增文件 Item.php 代碼如下
<?php namespace App;
use Illuminate\Database\Eloquent\Model;
class Item extends Model {
protected $fillable = ['name', 'price'];
protected $guarded = ['id'];
/**
* The database table used by the model.
* default: tbl_items
* @var string
*/
// protected $table = 'tbl_items';
public function fetchAll(){
$items = $this->all()->toJson();
return $items;
}
}
使用瀏覽器訪問http://yourIp/item/1,即可列出所有的item數(shù)據(jù)
五、Laravel結(jié)合Redis
直連DB是不夠的,很快數(shù)據(jù)庫訪問就會成為系統(tǒng)的瓶頸。我們引入緩存Redis。還是一樣的思路,先讓系統(tǒng)跑起來。
1、安裝啟動Redis
安裝
$ wget http://download.redis.io/releases/redis-3.0.1.tar.gz $ tar xzf redis-3.0.1.tar.gz $ cd redis-3.0.1 $ make
啟動
$ src/redis-server
查看官方下載和安裝文檔,只需要幾個命令即可
2、安裝PHP PRedis
PRedis是PHP訪問redis的擴展包,只需要下載原碼即可,不需要安裝PHP擴展(如php-redis.so)。但在這之前要介紹一個composer,因為laravel通過它來安裝第三方程序包(管理依賴關(guān)系)。
cd 到你的App所在路徑,修改composer.json,在require字段里,添加"predis/predis":"~1.0.1",然后當(dāng)前目錄下 sudo composer update,此時就會自動下載包需要的擴展包,這些擴展包將會被放在vendor目錄下。如果出現(xiàn)內(nèi)存不夠這些報錯,現(xiàn)在看來是內(nèi)存分配不夠的原因,重啟一下服務(wù)器即可,徹底解決的辦法要修改服務(wù)器配置,但我不清楚改哪里,后續(xù)再補
配置相關(guān)配置,查看官方文檔即可。主要是配置config/database.php
'redis' => array(
'cluster' => false,
'default' => array('host' => '127.0.0.1', 'port' => 6379)
)
3、coding
<?php namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\User as User;
use Illuminate\Support\Facades\Redis as Redis;
class UserController extends Controller {
// use User;
private $model;
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->model = new User();
}
/**
* Show
*
* @return Response
*/
public function showUser($id)
{
$redis = Redis::connection('default');
$cacheUsers = $redis->get('userList');
if( $cacheUsers ){
$users = $cacheUsers;
print_r($users);
Log::info('獲取用戶列表,通過redis');
}else{
$users = $this->model->fetchAll();
$redis->set('userList', $users);
print_r($users);
Log::info('獲取用戶列表,通過msyql');
}
}
}
- php操作redis數(shù)據(jù)庫常見方法實例總結(jié)
- PHP操作Redis數(shù)據(jù)庫常用方法示例
- PHP數(shù)據(jù)庫操作三:redis用法分析
- PHP實現(xiàn)的redis主從數(shù)據(jù)庫狀態(tài)檢測功能示例
- php實現(xiàn)redis數(shù)據(jù)庫指定庫號遷移的方法
- 30個php操作redis常用方法代碼例子
- redis 隊列操作的例子(php)
- php結(jié)合redis實現(xiàn)高并發(fā)下的搶購、秒殺功能的實例
- php Session存儲到Redis的方法
- PHP操作Redis常用技巧總結(jié)
- php+redis實現(xiàn)商城秒殺功能
- php操作redis緩存方法分享
- php操作Redis數(shù)據(jù)庫基本示例【安裝、連接、設(shè)置、查詢、斷開】
相關(guān)文章
Laravel5.4框架使用socialite實現(xiàn)github登錄的方法
這篇文章主要介紹了Laravel5.4框架使用socialite實現(xiàn)github登錄的方法,結(jié)合實例形式分析了Laravel相關(guān)下載、安裝、配置及github登陸、注冊、設(shè)置等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
ThinkPHP框架任意代碼執(zhí)行漏洞的利用及其修復(fù)方法
這篇文章主要介紹了ThinkPHP框架任意代碼執(zhí)行漏洞的利用及其修復(fù)方法,該漏洞的修復(fù)對于廣大使用ThinkPHP的開發(fā)人員來說尤為重要!需要的朋友可以參考下2014-07-07

