default.php 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307
  1. <?php
  2. # 集成项目的大部分配置,此为默认设置。环境不同,以下的配置也有可能不同,可以根据项目名建立配置文件
  3. # 基本配置
  4. $config['base'] = array
  5. (
  6. # 项目部署的相对路径(部署在服务器的根目录,如果不定义DEVER_PROJECT_NAME,则本项必须启用并有效)
  7. 'path' => DIRECTORY_SEPARATOR . 'workspace' . DIRECTORY_SEPARATOR,
  8. # 访问assets目录的物理路径
  9. 'assets' => DEVER_APP_PATH . 'assets' . DIRECTORY_SEPARATOR,
  10. # 访问data目录的物理路径
  11. 'data' => DEVER_PROJECT_PATH . 'data' . DIRECTORY_SEPARATOR,
  12. # 访问当前项目目录的物理路径,如果项目和dever类库在一个目录中,则为DEVER_PATH,如果不在,则为DEVER_APP_PATH,当然也可随意更改,这里目前只影响合并操作
  13. 'workspace' => DEVER_APP_PATH,
  14. # 定义api的token明文,如果和其他业务有合作,建议使用系统自带的接口api,自带加密解密程序。
  15. 'token' => 'dever_api_2016',
  16. # 是否启用nocache,如果是互动类的项目且主域增加了cdn,建议开启
  17. 'clearHeaderCache' => false,
  18. # api文档生成是否开启,开启后,将会根据访问来生成文档。生产环境建议禁止
  19. 'apiDoc' => true,
  20. # api日志是否开启,开启后,将会记录所有带有_api后缀方法的请求参数和响应参数
  21. 'apiLog' => false,
  22. # 定义自动转为api的目录,可以将该目录下的所有类的公共方法,都转为可以访问的api,开启该功能可能有安全性问题。
  23. 'apiOpenPath' => 'src',
  24. # 启用后,将会根据api目录下的配置文件自动定位api
  25. //'apiConfig' => true,
  26. # 启用apiConfig后,生成的signature保存的位置:file和db,默认为db
  27. //'apiSignature' => 'file',
  28. # 开启用户触发cron,主要用于无法加到系统计划任务的虚拟主机,必须安装manage组件,谨慎开启,会稍微影响程序执行效率
  29. //'cron' => true,
  30. );
  31. # 模板配置
  32. $config['template'] = array
  33. (
  34. # 是否启用静态资源域名动态化,启用之后,静态资源的域名将动态加载,适合使用多个域名或publish启用
  35. 'domain' => true,
  36. # 是否开启强制刷新页面缓存
  37. 'shell' => 'temp',
  38. # 是否开启手动更改模板名称,允许通过$_GET的方式来更改当前模板,值为$_GET的key值,默认关闭
  39. //'name' => 'template',
  40. # publish 是否发布,此项开启后,系统不会检测service(意味着不用将service打包上线),适合生产环境,并能对代码起到一定的加密保护。
  41. //'publish' => true,
  42. );
  43. # 数据库配置
  44. $config['database'] = array
  45. (
  46. # database 中的reuqest的兼容定义,如果启用了该选项,需要自行开发database/compatible目录下相对应的数据表文件中的request方法。
  47. //'compatible' => 'model',
  48. # 是否开启sql自动优化,将sql中的select * 转换为 select a,b形式,将sql中的where条件按照索引从左到右自动排序,必须打开上述的opt选项,数据量大时建议打开。
  49. //'sql' => true,
  50. # 关闭自助建表,生产环境建议开启,开启之后无法对数据表结构进行更新操作
  51. //'create' => true,
  52. # 是否开启mysql自助优化功能,开启后,会记录所有where条件和order的字段,可以方便的在后台进行分析、增加索引,必须安装manage组件
  53. 'opt' => true,
  54. # 默认数据库配置
  55. 'default' => array
  56. (
  57. 'type' => 'pdo',
  58. 'pdo_type' => 'mysql',//pgsql
  59. 'host' => array
  60. (
  61. 'read' => 'web-mysql:3306',
  62. 'update' => 'web-mysql:3306',
  63. //'read' => '192.168.1.203:3307',
  64. //'update' => '192.168.1.203:3307',
  65. ),
  66. 'database' => 'dever',
  67. 'username' => 'root',
  68. 'password' => '123456',
  69. 'charset' => 'utf8',
  70. ),
  71. # 持久化服务器,只负责保存数据,跟读写分离差不多,但可以更换不同的数据库类型
  72. /*
  73. 'save' => array
  74. (
  75. 'type' => 'pdo',
  76. 'host' => 'localhost:3306',
  77. 'database' => 'dever_test',
  78. 'username' => 'root',
  79. 'password' => '123456',
  80. 'charset' => 'utf8',
  81. ),
  82. */
  83. # 迁移旧的数据库服务器,使用方法:Dever::db('atom/article:old')
  84. 'old' => array
  85. (
  86. 'type' => 'pdo',
  87. 'host' => '192.168.1.205:3307',
  88. 'database' => 'old',
  89. 'username' => 'root',
  90. 'password' => '123456',
  91. 'charset' => 'utf8',
  92. ),
  93. 'elastic' => array
  94. (
  95. 'type' => 'elastic',
  96. 'host' => '192.168.1.203:9200',
  97. 'database' => 'purify1',
  98. 'username' => 'elastic',
  99. 'password' => 'changeme',
  100. # 分词插件 只针对text类型的字段有效
  101. 'analyzer' => 'ik_max_word',
  102. # 基本配置
  103. 'setting' => array
  104. (
  105. 'index' => array
  106. (
  107. 'number_of_shards' => 2,
  108. 'number_of_replicas' => 1,
  109. ),
  110. ),
  111. ),
  112. 'mongo' => array
  113. (
  114. 'type' => 'mongo',
  115. 'host' => '192.168.1.203:27017',
  116. 'database' => 'dever',
  117. 'timeout' => 1000,
  118. )
  119. );
  120. # 缓存配置
  121. $config['cache'] = array
  122. (
  123. # 启用mysql数据库缓存,这个缓存是根据表名自动生成,dever::load形式和service的all、one形式均自动支持,无需手动添加
  124. 'mysql' => 0,
  125. # 启用页面缓存 会根据当前的url来生成缓存,相当于页面静态化。
  126. 'html' => 0,
  127. # 启用数据级别缓存 这个缓存是程序员自定义的:Dever::cache('name', 'value', 3600);
  128. 'data' => 3600,
  129. # 启用load加载器缓存,一般不加载
  130. 'load' => 0,
  131. # 启用load加载器的远程加载缓存
  132. 'curl' => 3600,
  133. # 缓存精细控制,可以根据缓存的key(mysql为表名、service为小写类名,规则是模糊匹配),来控制每一条缓存
  134. 'loadKey' => array
  135. (
  136. # 定义缓存名为auth.data的缓存时间
  137. 'auth.data' => 200,
  138. ),
  139. # 缓存清理的参数名,请通过shell=clearcache执行
  140. 'shell' => 'clearcache',
  141. # 是否启用key失效时间记录,启用之后,将会记录每个key的失效时间
  142. 'expire' => true,
  143. # 缓存类型
  144. 'type' => 'memcache',//memcache、redis
  145. # 缓存保存方式,支持多个数据源、多台缓存服务器
  146. 'store' => array
  147. (
  148. /*
  149. array
  150. (
  151. 'host' => 'server-memcached',
  152. 'port' => '11211',
  153. 'weight' => 100,
  154. ),
  155. array
  156. (
  157. 'host' => 'server-memcached',
  158. 'port' => '11212',
  159. 'weight' => 100,
  160. ),
  161. */
  162. ),
  163. );
  164. # debug配置
  165. $config['debug'] = array
  166. (
  167. # 开启错误提示 生产环境建议禁止
  168. 'error' => true,
  169. # 错误日志记录,为空则不开启,type可选值为file、syslog、udp、http,默认为syslog
  170. 'log' => array('type' => 'syslog','host' => 'host', 'port' => 'port'),
  171. # 是否开启记录超时时间,单位为秒
  172. 'overtime' => 3,
  173. # 开始访问报告
  174. # 生产环境建议禁止或添加ip限制,多个ip用逗号隔开
  175. # 如禁止,值为false,下述shell也将失效
  176. # 值为2,则开启强制模式,任何输出都将打印debug
  177. 'request' => Dever::ip(),
  178. # 设定打印访问报告的指令
  179. 'shell' => 'debug',
  180. # 以上指令,请通过&shell=debug来执行,如果你想设置断点或者打印当前业务逻辑下的sql,请直接用Dever::debug();打印数据
  181. );
  182. $local = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : 'localhost';
  183. # 本地可用这个
  184. $host = 'http://'.$local . '/';
  185. # 定义assets的域名
  186. $assets = DEVER_APP_HOST . 'assets/';
  187. $project_host = $host . '' . DEVER_PROJECT . '/';
  188. # 定义data域名
  189. $data_host = $project_host . 'data/';
  190. if (DEVER_APP_NAME == 'manage') {
  191. $assets = $host . 'dever_package/manage/assets/';
  192. }
  193. # host 设置
  194. $config['host'] = array
  195. (
  196. # 跟域名
  197. 'base' => DEVER_APP_HOST,
  198. # cookie 域名
  199. 'cookie' => '',
  200. # assets网络路径,会自动将assets替换为assets/模板
  201. 'assets' => $assets,
  202. # 当前的assets路径
  203. 'css' => $assets . 'css/',
  204. 'js' => $assets . 'js/',
  205. 'img' => $assets . 'img/',
  206. 'images' => $assets . 'images/',
  207. 'lib' => $assets . 'lib/',
  208. # script组件路径
  209. 'script' => $host . 'dever_package/script/assets/',
  210. # 合并之后的网络路径,填写之后自动合并资源,不填写则不合并,适合把资源放到云端
  211. //'merge' => $data_host . 'assets/' . DEVER_PROJECT . '/',
  212. # 上传系统的上传路径的域名(不带action)
  213. 'upload'=> $project_host . 'upload/?save',
  214. # 上传系统的资源访问地址
  215. 'uploadRes' => $data_host . 'upload/',
  216. # 域名替换,支持*通配符
  217. /*
  218. 'domain' => array
  219. (
  220. 'rule' => function()
  221. {
  222. $source = $desc = 'http://';
  223. if(function_exists('isHttps') && isHttps())
  224. {
  225. $desc = 'https://';
  226. }
  227. return array($source, $desc);
  228. },
  229. 'replace' => array('*.selfimg.com.cn')
  230. ),
  231. */
  232. # 是否启用代理功能
  233. //'proxy' => $host . 'dever/application/plant/main/?data.proxy?',
  234. # 项目定义,Dever::load将自动转为这个配置,替换掉data/project/default.php里的数据
  235. 'project' => array
  236. (
  237. 'test' => array('url' => '', 'path' => ''),
  238. ),
  239. 'apiServer' => array
  240. (
  241. 'type' => 'tcp',
  242. # 以下为tcp模式特有的配置
  243. # 是否使用后台运行
  244. //'backend' => 1,
  245. # 以下为swoole的配置
  246. 'worker_num' => 1,
  247. ),
  248. );
  249. if (DEVER_APP_NAME == 'manage') {
  250. $config['host']['merge'] = false;
  251. }
  252. return $config;