一.架構(gòu)。確認你安裝 的架構(gòu)是什么 lamp ,還是 lnmp。首先需要能搭建出環(huán)境
在張灣等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站制作、網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需定制開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,營銷型網(wǎng)站建設(shè),外貿(mào)網(wǎng)站建設(shè),張灣網(wǎng)站建設(shè)費用合理。
1。兩者都要安裝 php ,其中 php 安裝的過程有很多
可以參考一下:php 源碼安裝
這個安裝是 php5的,如果安裝的 是 php7,編譯會有一點不同:
安裝 php -
2。都需要安裝 mysql
mysql 源碼安裝
3。如果需要安裝apache:
apache 安裝
apache 都其他配置,請在本頁面搜索:apache -
如果需要安裝 nginx:
nginx 訪問 php -
二.依賴模塊編譯。這種安裝環(huán)境主要看你程序當中用到了那些 依賴模塊,編譯的時候需要注意
包括 nginx /apache ,php
三.配置。上面已經(jīng)有相關(guān)配置介紹,需要自己去熟悉相關(guān)都配置是什么意思,需要哪些配置。
四.此處遷移還涉及到數(shù)據(jù)庫到遷移,可以參考一下相關(guān)命令
建表
phinx\bin\phinx.bat migrate -e production
建設(shè) phinx.yml文件
paths:
migrations: %%PHINX_CONFIG_DIR%%\database\migrations
seeds: %%PHINX_CONFIG_DIR%%\database\seeds
environments:
default_migration_table: phinxlog
default_database: development
production:
adapter: mysql
host: localhost
name: jitamin2
user: root
pass: ‘‘
port: 3306
charset: utf8
development:
adapter: mysql
host: localhost
name: development_db
user: root
pass: ‘‘
port: 3306
charset: utf8
testing:
adapter: mysql
host: localhost
name: testing_db
user: root
pass: ‘‘
port: 3306
charset: utf8
數(shù)據(jù)遷移命令如下:
phinx\bin\phinx.bat seed:run -e production
%%PHINX_CONFIG_DIR%%\database\seeds下面的文件示例CreateGroupsTable.php如下:
?php
/*
* This file is part of Jitamin.
*
* Copyright (C) Jitamin Team
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
use Jitamin\Foundation\Security\Role;
use Phinx\Seed\AbstractSeed;
class UserSeeder extends AbstractSeed
{
/**
* Run Method.
*/
public function run()
{
$data = [
[
‘username‘ = ‘a(chǎn)dmin‘,
‘password‘ = bcrypt(‘a(chǎn)dmin‘),
‘email‘ = ‘a(chǎn)dmin@admin.com‘,
‘role‘ = Role::APP_ADMIN,
],
];
$users = $this-table(‘users‘);
$users-insert($data)
-save();
}
}
數(shù)據(jù)庫的安全性、完整性、并發(fā)控制和恢復(fù)
from:
為了保證數(shù)據(jù)庫數(shù)據(jù)的安全可靠性和正確有效,DBMS必須提供統(tǒng)一的數(shù)據(jù)保護功能。數(shù)據(jù)保護也為數(shù)據(jù)控制,主要包括數(shù)據(jù)庫的安全性、完整性、并發(fā)控制和恢復(fù)。
1. 數(shù)據(jù)庫的存取控制
ORACLE保護信息的方法采用任意存取控制來控制全部用戶對命名對象的存取。用戶對對象的存取受特權(quán)控制。一種特權(quán)是存取一命名對象的許可,為一種規(guī)定格式。
ORACLE使用多種不同的機制管理數(shù)據(jù)庫安全性,其中有兩種機制:模式和用戶。模式為模式對象的集合,模式對象如表、視圖、過程和包等。第一數(shù)據(jù)庫有一組模式。
每一ORACLE數(shù)據(jù)庫有一組合法的用戶,可存取一數(shù)據(jù)庫,可運行一數(shù)據(jù)庫應(yīng)用和使用該用戶各連接到定義該用戶的數(shù)據(jù)庫。當建立一數(shù)據(jù)庫用戶時,對該用戶建立一個相應(yīng)的模式,模式名與用戶名相同。一旦用戶連接一數(shù)據(jù)庫,該用戶就可存取相應(yīng)模式中的全部對象,一個用戶僅與同名的模式相聯(lián)系,所以用戶和模式是類似的。
用戶的存取權(quán)利受用戶安全域的設(shè)置所控制,在建立一個數(shù)據(jù)庫的新用戶或更改一已有用戶時,安全管理員對用戶安全域有下列決策:
l 是由數(shù)據(jù)庫系統(tǒng)還是由操作系統(tǒng)維護用戶授權(quán)信息。
l 設(shè)置用戶的缺省表空間和臨時表空間。
l 列出用戶可存的表空間和在表空間中可使用空間份額。
l 設(shè)置用戶資源限制的環(huán)境文件,該限制規(guī)定了用戶可用的系統(tǒng)資源的總量。
l 規(guī)定用戶具有的特權(quán)和角色,可存取相應(yīng)的對象。
每一個用戶有一個安全域,它是一組特性,可決定下列內(nèi)容:
l 用戶可用的特權(quán)和角色;
l 用戶可用的表空間的份額;
l 用戶的系統(tǒng)資源限制。
1) 用戶鑒別:
為了防止非授權(quán)的數(shù)據(jù)庫用戶的使用,ORACLE提供二種確認方法
操作系統(tǒng)確認和相應(yīng)的ORACLE數(shù)據(jù)庫確認。
如果操作系統(tǒng)允許,ORACLE可使用操作系統(tǒng)所維護的信息來鑒定用戶。由操作系統(tǒng)鑒定用戶的優(yōu)點是:
l 用戶可更方便地連接到ORACLE,不需要指定用戶名和口令。
l 對用戶授權(quán)的控制集中在操作系統(tǒng),ORACLE不需要存儲和管理用戶口令。然而用戶名在數(shù)據(jù)庫中仍然要維護。
l 在數(shù)據(jù)庫中的用戶名項和操作系統(tǒng)審計跟蹤相對應(yīng)。
ORACLE數(shù)據(jù)庫方式的用戶確認:ORACLE利用存儲在數(shù)據(jù)庫中的信息可鑒定試圖接到數(shù)據(jù)庫的一用戶,這種鑒別方法僅當操作系統(tǒng)不能用于數(shù)據(jù)庫用戶鑒別時才使用。當用戶使用一ORACLE數(shù)據(jù)庫時執(zhí)行用戶鑒別。每個用戶在建立時有一個口令,用戶口令在建立對數(shù)據(jù)庫連接時使用,以防止對數(shù)據(jù)庫非授權(quán)的使用。用戶的口令以密碼的格式存儲在數(shù)據(jù)庫數(shù)據(jù)字典中,用戶可隨時修改其口令。
2) 用戶的表空間設(shè)置和定額
關(guān)于表空間的使用有幾種設(shè)置選擇:
l 用戶的缺省表空間;
l 用戶的臨時表空間;
l 數(shù)據(jù)庫表空間的空間使用定額。
3) 用戶資源限制和環(huán)境文件
用戶可用的各種系統(tǒng)資源總量的限制是用戶安全域的部分。利用顯式地設(shè)置資源限制;安全管理員可防止用戶無控制地消耗寶貴的系統(tǒng)資源。資源限制是由環(huán)境文件管理。一個環(huán)境文件是命名的一組賦給用戶的資源限制。另外ORACLE為安全管理員在數(shù)據(jù)庫級提供使能或使不能實施環(huán)境文件資源限制的選擇。
ORACLE可限制幾種類型的系統(tǒng)資源的使用,每種資源可在會話級、調(diào)用級或兩者上控制。在會話級:每一次用戶連接到一數(shù)據(jù)庫,建立一會話。每一個會話在執(zhí)行SQL語句的計算機上耗費CPU時間和內(nèi)存量進行限制。對ORACLE的幾種資源限制可在會話級上設(shè)置。如果會話級資源限制被超過,當前語句被中止(回滾),并返回指明會話限制已達到的信息。此時,當前事務(wù)中所有之前執(zhí)行的語句不受影響,此時僅可作COMMIT、ROLLBACK或刪除對數(shù)據(jù)庫的連接等操作,進行其它操作都將出錯。
在調(diào)用級:在SQL語句執(zhí)行時,處理該語句有好幾步,為了防止過多地調(diào)用系統(tǒng),ORACLE在調(diào)用級可設(shè)置幾種資源限制。如果調(diào)用級的資源限制被超過,語句處理被停止,該語句被回滾,并返回一錯誤。然而當前事務(wù)的已執(zhí)行所用語句不受影響,用戶會話繼續(xù)連接。
二、 數(shù)據(jù)完整性
它是指數(shù)據(jù)的正確性和相容性。數(shù)據(jù)的完整性是為了防止數(shù)據(jù)庫存在不符合主義的數(shù)據(jù),防止錯誤信息輸入和輸出,即數(shù)據(jù)要遵守由DBA或應(yīng)用開發(fā)者所決定的一組預(yù)定義的規(guī)則。ORACLE應(yīng)用于關(guān)系數(shù)據(jù)庫的表的數(shù)據(jù)完整性有下列類型:
l 在插入或修改表的行時允許不允許包含有空值的列,稱為空與非空規(guī)則。
l 唯一列值規(guī)則,允許插入或修改的表行在該列上的值唯一。
l 引用完整性規(guī)則,同關(guān)系模型定義
l 用戶對定義的規(guī)則,為復(fù)雜性完整性檢查。
ORACLE允許定義和實施上述每一種類型的數(shù)據(jù)完整性規(guī)則,這些規(guī)則可用完整性約束和數(shù)據(jù)庫觸發(fā)器定義。
完整性約束,是對表的列定義一規(guī)則的說明性方法。
數(shù)據(jù)庫觸發(fā)器,是使用非說明方法實施完整性規(guī)則,利用數(shù)據(jù)庫觸發(fā)器(存儲的數(shù)據(jù)庫過程)可定義和實施任何類型的完整性規(guī)則。
1. 完整性約束
ORACLE利用完整性約束機制防止無效的數(shù)據(jù)進入數(shù)據(jù)庫的基表,如果任何DML執(zhí)行結(jié)果破壞完整性約束,該語句被回滾并返回一上個錯誤。ORACLE實現(xiàn)的完整性約束完全遵守ANSI
X3。135-1989和ISO9075-1989標準。
利用完整性約束實施數(shù)據(jù)完整性規(guī)則有下列優(yōu)點:
l 定義或更改表時,不需要程序設(shè)計,便很容易地編寫程序并可消除程序性錯誤,其功能是由ORACLE控制。所以說明性完整性約束優(yōu)于應(yīng)用代碼和數(shù)據(jù)庫觸發(fā)器。
l 對表所定義的完整性約束是存儲在數(shù)據(jù)字典中,所以由任何應(yīng)用進入的數(shù)據(jù)都必須遵守與表相關(guān)聯(lián)的完整性約束。
l 具有最大的開發(fā)能力。當由完整性約束所實施的事務(wù)規(guī)則改變時,管理員只需改變完整性約束的定義,所有應(yīng)用自動地遵守所修改的約束。
l 由于完整性約束存儲在數(shù)據(jù)字典中,數(shù)據(jù)庫應(yīng)用可利用這些信息,在SQL語句執(zhí)行之前或由ORACLE檢查之前,就可立即反饋信息。
l 由于完整性約束說明的語義是清楚地定義,對于每一指定說明規(guī)則可實現(xiàn)性能優(yōu)化。
l
由于完整性約束可臨時地使不能,以致在裝入大量數(shù)據(jù)時可避免約束檢索的開銷。當數(shù)據(jù)庫裝入完成時,完整性約束可容易地使其能,任何破壞完整性約束的任何新行在例外表中列出。
ORACLE的DBA和應(yīng)用開始者對列的值輸入可使用的完整性約束有下列類型:
l NOT NULL約束:如果在表的一列的值不允許為空,則需在該列指定NOT NULL約束。
l
UNIQUE碼約束:在表指定的列或組列上不允許兩行是具有重復(fù)值時,則需要該列或組列上指定UNIQUE碼完整性約束。在UNIQUE碼約束定義中的列或組列稱為唯一碼。所有唯一完整性約束是用索引方法實施。
l PRIMARY KEY約束:在數(shù)據(jù)庫中每一個表可有一個PRIMARY KEY約束。包含在PRIMARY
KEY完整性約束的列或組列稱為主碼,每個表可有一個主碼。ORACLE使用索引實施PRIMARY KEY約束。
l FOREIGN
KEY約束(可稱引用約束):在關(guān)系數(shù)據(jù)庫中表可通過公共列相關(guān)聯(lián),該規(guī)則控制必須維護的列之間的關(guān)系。包含在引用完整性約束定義的列或組列稱為外來碼。由外來碼所引用的表中的唯一碼或方碼,稱為引用碼。包含有外來碼的表稱為子表或從屬表。由子表的外來碼所引用的表稱為雙親表或引用表。如果對表的每一行,其外來碼的值必須與主碼中一值相匹配,則需指定引用完整性約束。
l
CHECK約束:表的每行對一指定的條件必須是TRUE或未知,則需在一列或列組上指定CHECK完整性約束。如果在發(fā)出一個DML語句時,CHECK約束的條件計算得FALSE時,該語句被回滾。
3. 并發(fā)控制
數(shù)據(jù)庫是一個共享資源,可為多個應(yīng)用程序所共享。這些程序可串行運行,但在許多情況下,由于應(yīng)用程序涉及的數(shù)據(jù)量可能很大,常常會涉及輸入/輸出的交換。為了有效地利用數(shù)據(jù)庫資源,可能多個程序或一個程序的多個進程并行地運行,這就是數(shù)據(jù)庫的并行操作。在多用戶數(shù)據(jù)庫環(huán)境中,多個用戶程序可并行地存取數(shù)據(jù)庫,如果不對并發(fā)操作進行控制,會存取不正確的數(shù)據(jù),或破壞數(shù)據(jù)庫數(shù)據(jù)的一致性。
例:在飛機票售票中,有兩個訂票員(T1,T2)對某航線(A)的機動性票作事務(wù)處理,操作過程如圖所示:
數(shù)據(jù)庫中的A111100
T1 READ A A:=A-1 WRITE A
T2 READ A A:=A-1 WRITE A
T1工作區(qū)中的A110000
T2工作區(qū)中的A 11000
首先T1讀A,接著T2也讀A。然后T1將其工作區(qū)中的A減1,T2也采取同樣動作,它們都得0值,最后分別將0值寫回數(shù)據(jù)庫。在這過程中沒有任何非法操作,但實際上多出一張機票。這種情況稱為數(shù)據(jù)庫的不一致性,這種不一致性是由于并行操作而產(chǎn)生的。所謂不一致,實際上是由于處理程序工作區(qū)中的數(shù)據(jù)與數(shù)據(jù)庫中的數(shù)據(jù)不一致所造成的。如果處理程序不對數(shù)據(jù)庫中的數(shù)據(jù)進行修改,則決不會造成任何不一致。另一方面,如果沒有并行操作發(fā)生,則這種臨時的不一致也不會造成什么問題。數(shù)據(jù)不一致總是是由兩個因素造成:一是對數(shù)據(jù)的修改,二是并行操作的發(fā)生。因此為了保持數(shù)據(jù)庫的一致性,必須對并行操作進行控制。最常用的措施是對數(shù)據(jù)進行封鎖。
1) 數(shù)據(jù)庫不一致的類型
l 不一致性
在一事務(wù)期間,其它提交的或未提交事務(wù)的修改是顯然的,以致由查詢所返回的數(shù)據(jù)集不與任何點相一致。
l 不可重復(fù)讀
在一個事務(wù)范圍內(nèi),兩個相同查詢將返回不同數(shù)據(jù),由于查詢注意到其它提交事務(wù)的修改而引起。
l 讀臟數(shù)據(jù)
如果事務(wù)T1將一值(A)修改,然后事務(wù)T2讀該值,在這之后T1由于某種原因撤銷對該值的修改,這樣造成T2讀取的值是臟的。
l 丟失更改
在一事務(wù)中一修改重寫另一事務(wù)的修改,如上述飛機票售票例子。
l 破壞性的DDL操作
在一用戶修改一表的數(shù)據(jù)時,另一用戶同時更改或刪除該表。
1) 封鎖
在多用戶數(shù)據(jù)庫中一般采用某些數(shù)據(jù)封鎖來解決并發(fā)操作中的數(shù)據(jù)一致性和完整性問題。封鎖是防止存取同一資源的用戶之間破壞性的干擾的機制,該干擾是指不正確地修改數(shù)據(jù)或不正確地更改數(shù)據(jù)結(jié)構(gòu)。
在多用戶數(shù)據(jù)庫中使用兩種封鎖:排它(專用)封鎖和共享封鎖。排它封鎖禁止相關(guān)資源的共享,如果一事務(wù)以排它方式封鎖一資源,僅僅該事務(wù)可更改該資源,直至釋放排它封鎖。共享封鎖允許相關(guān)資源可以共享,幾個用戶可同時讀同一數(shù)據(jù),幾個事務(wù)可在同一資源上獲取共享封鎖。共享封鎖比排它封鎖具有更高的數(shù)據(jù)并行性。
在多用戶系統(tǒng)中使用封鎖后會出現(xiàn)死鎖,引起一些事務(wù)不能繼續(xù)工作。當兩個或多個用戶彼此等待所封鎖數(shù)據(jù)時可發(fā)生死鎖。
2) ORACLE多種一致性模型。
ORACLE利用事務(wù)和封鎖機制提供數(shù)據(jù)并發(fā)存取和數(shù)據(jù)完整性。在一事務(wù)內(nèi)由語句獲取的全部封鎖在事務(wù)期間被保持,防止其它并行事務(wù)的破壞性干擾。一個事務(wù)的SQL語句所作的修改在它提交之后所啟動的事務(wù)中才是可見的。在一事務(wù)中由語句所獲取的全部封鎖在該事務(wù)提交或回滾時被釋放。
ORACLE在兩個不同級上提供讀一致性:語句級讀一致性和事務(wù)級一致性。ORCLE總是實施語句級讀一致性,保證單個查詢所返回的數(shù)據(jù)與該查詢開始時刻相一致。所以一個查詢從不會看到在查詢執(zhí)行過程中提交的其它事務(wù)所作的任何修改。為了實現(xiàn)語句級讀一致性,在查詢進入執(zhí)行階段時,在注視SCN的時候為止所提交的數(shù)據(jù)是有效的,而在語句執(zhí)行開始之后其它事務(wù)提交的任何修改,查詢將是看不到的。
ORACLE允許選擇實施事務(wù)級讀一致性,它保證在同一事務(wù)內(nèi)所有查詢的數(shù)據(jù)
4) 封鎖機制
ORACLE自動地使用不同封鎖類型來控制數(shù)據(jù)的并行存取,防止用戶之間的破壞性干擾。ORACLE為一事務(wù)自動地封鎖一資源以防止其它事務(wù)對同一資源的排它封鎖。在某種事件出現(xiàn)或事務(wù)不再需要該資源時自動地釋放。
ORACLE將封鎖分為下列類:
l
數(shù)據(jù)封鎖:數(shù)據(jù)封鎖保護表數(shù)據(jù),在多個用戶并行存取數(shù)據(jù)時保證數(shù)據(jù)的完整性。數(shù)據(jù)封鎖防止相沖突的DML和DDL操作的破壞性干擾。DML操作可在兩個級獲取數(shù)據(jù)封鎖:指定行封鎖和整個表封鎖,在防止沖突的DDL操作時也需表封鎖。當行要被修改時,事務(wù)在該行獲取排它數(shù)據(jù)封鎖。表封鎖可以有下列方式:行共享、行排它、共享封鎖、共享行排它和排它封鎖。
l DDL封鎖(字典封鎖)
DDL封鎖保護模式對象(如表)的定義,DDL操作將影響對象,一個DDL語句隱式地提交一個事務(wù)。當任何DDL事務(wù)需要時由ORACLE自動獲取字典封鎖,用戶不能顯式地請求DDL封鎖。在DDL操作期間,被修改或引用的模式對象被封鎖。
l 內(nèi)部封鎖:保護內(nèi)部數(shù)據(jù)庫和內(nèi)存結(jié)構(gòu),這些結(jié)構(gòu)對用戶是不可見的。