PHP的Laravel框架結合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
- 關于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文件夾,使用以下命令修改其文件讀寫權限,讓Nginx用戶能讀寫它
sudo chmod -R 766 storage sudo chmod -R 766 vendor
四、讓MVC跑起來!
在此之前,你應該讀一下官方文檔 路由、控制器、數(shù)據(jù)庫使用基礎、Eloquent ORM
至此,可以開始coding,開發(fā)一個 MVC的demo了,此demo的功能是將數(shù)據(jù)庫表tbl_item從數(shù)據(jù)庫里讀出來,并以json格式響應給瀏覽器。
假設你已經(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結合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通過它來安裝第三方程序包(管理依賴關系)。
cd 到你的App所在路徑,修改composer.json,在require字段里,添加"predis/predis":"~1.0.1",然后當前目錄下 sudo composer update,此時就會自動下載包需要的擴展包,這些擴展包將會被放在vendor目錄下。如果出現(xiàn)內(nèi)存不夠這些報錯,現(xiàn)在看來是內(nèi)存分配不夠的原因,重啟一下服務器即可,徹底解決的辦法要修改服務器配置,但我不清楚改哪里,后續(xù)再補
配置相關配置,查看官方文檔即可。主要是配置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ù)庫常見方法實例總結
- 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結合redis實現(xiàn)高并發(fā)下的搶購、秒殺功能的實例
- php Session存儲到Redis的方法
- PHP操作Redis常用技巧總結
- php+redis實現(xiàn)商城秒殺功能
- php操作redis緩存方法分享
- php操作Redis數(shù)據(jù)庫基本示例【安裝、連接、設置、查詢、斷開】
相關文章
Laravel5.4框架使用socialite實現(xiàn)github登錄的方法
這篇文章主要介紹了Laravel5.4框架使用socialite實現(xiàn)github登錄的方法,結合實例形式分析了Laravel相關下載、安裝、配置及github登陸、注冊、設置等相關操作技巧,需要的朋友可以參考下2019-03-03ThinkPHP框架任意代碼執(zhí)行漏洞的利用及其修復方法
這篇文章主要介紹了ThinkPHP框架任意代碼執(zhí)行漏洞的利用及其修復方法,該漏洞的修復對于廣大使用ThinkPHP的開發(fā)人員來說尤為重要!需要的朋友可以參考下2014-07-07