• 为员工创造价值,为客户创造价值;
  • 为推动全社会进步而努力;
  • 成为中国的企业IT人才培养解决方案提供商.

400-689-2779

SELinux开发全解析:从基础概念到实战应用的深度技术指南

SELinux开发全解析:从基础概念到实战应用的深度技术指南

授课机构: 南京柯普瑞IT学校

上课地点: 校区地址

成交/评价:

联系电话: 400-689-2779

SELinux开发全解析:从基础概念到实战应用的深度技术指南课程详情

SELinux开发核心技术体系深度解析

一、访问控制模型的技术演进与SELinux的定位

现代操作系统的安全机制中,访问控制模型的发展贯穿了从基础到复杂的技术迭代。早期的访问控制依赖简单的自主访问控制(DAC),但这种模型存在明显局限性——权限分配过于依赖用户自主操作,容易因误配置或恶意用户导致安全漏洞。随着系统复杂度提升,强制访问控制(MAC)应运而生,其核心是通过系统级策略统一管理资源访问,无论用户身份如何,都必须遵守预设规则。

SELinux(Security-Enhanced Linux)作为MAC的典型实现,其核心创新在于引入类型强制(Type Enforcement, TE)模型。TE模型通过为每个进程和文件分配唯一的安全上下文(Security Context),并基于策略定义不同类型间的访问权限,从根本上限制了进程的越权操作。这种设计不仅继承了MAC的强制约束特性,更通过细粒度的类型控制提升了策略的灵活性。

二、SELinux核心概念与技术基础

理解SELinux的运行机制,需从其“物质基础”——安全上下文(Security Context)开始。安全上下文通常由四部分组成:用户(User)、角色(Role)、类型(Type)和级别(Level,仅MLS场景),例如典型的上下文字符串unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023。其中,类型(Type)是TE模型的核心标识,决定了进程(Domain)和文件(Object)的访问权限边界。

Linux安全模块(LSM, Linux Security Module)为SELinux提供了内核级扩展接口。通过LSM框架,SELinux能够将安全策略嵌入到内核的关键操作点(如文件访问、进程执行、网络通信),在系统资源访问前执行策略检查。这种集成方式既了策略的高效执行,又保持了内核的模块化设计。

类型强制(Type Enforcement)的实现依赖两个核心机制:域转换(Domain Transition)和角色(Role)约束。域转换定义了进程在执行不同程序时的类型变化规则,例如当httpd_t类型的进程执行sshd程序时,需通过策略允许其转换为sshd_t类型。角色则作为用户与类型的中间层,限制用户可激活的域集合,例如普通用户可能仅能使用user_r角色,而管理员可使用sysadm_r角色。

三、SELinux策略语法与规则设计

SELinux策略的核心是通过特定语法定义的规则集合,其语法体系可分为基础元素与规则类型两大部分。基础元素包括对象类(Object Class)、权限(Permissions)、类型(Type)及属性(Attribute)。对象类定义了受保护资源的类型(如文件、套接字、进程),权限则是对该类资源可执行的操作(如读、写、执行)。

访问向量规则(Access Vector Rules)是策略的核心组成,其格式为allow source_type target_type:object_class { permission_set };,明确允许源类型(通常是进程域)对目标类型(通常是文件或其他资源)执行特定操作。例如allow httpd_t httpd_sys_content_t:file { read write };表示允许HTTP服务进程访问Web内容文件。

类型转换规则(Type Transition Rules)用于定义进程执行新程序时的类型变化,格式为type_transition source_type target_type:object_class new_type;。例如当init_t进程执行/usr/sbin/sshd程序(类型为sshd_exec_t)时,转换为sshd_t类型的规则可写为:type_transition init_t sshd_exec_t:process sshd_t;

此外,策略还支持布尔值(Boolean)、可调参数(Tunable)及约束(Constraints)等高级特性。布尔值允许动态启用/禁用一组规则(如httpd_can_network_connect控制HTTP服务是否可访问外部网络),可调参数则用于设置策略中的数值型配置(如文件大小限制)。约束规则可进一步限制访问条件,例如要求源类型与目标类型必须属于同一安全级别。

四、SELinux用户态设施与环境配置

SELinux的用户态设施主要包括配置文件、策略存储及调试工具。核心配置文件/etc/selinux/config定义了SELinux的运行模式(强制、许可、禁用)及当前策略类型(如targeted、mls)。策略存储目录/etc/selinux/$SELINUXTYPE/包含已编译的策略模块和上下文映射文件。

selinuxfs是一个虚拟文件系统,挂载于/sys/fs/selinux,提供内核SELinux子系统的运行时信息。通过访问/sys/fs/selinux/contexts可查看系统预定义的安全上下文模板,/sys/fs/selinux/policy则包含当前加载的策略版本信息。

进程的安全上下文可通过/proc/pid/attr/目录查看,例如/proc/1234/attr/current显示PID为1234的进程当前上下文,/proc/1234/attr/exec显示其执行新程序时的目标上下文。这些接口为调试进程权限问题提供了关键信息。

五、应用程序SELinux策略开发实战

为新应用程序开发SELinux策略包(PP, Policy Package)是SELinux开发的常见任务。开发前需明确两个关键问题:对象标签由谁定义?通常,文件标签由安装包(如RPM/DEB)在安装时通过selinux_contexts文件设置,而进程标签由策略规则动态分配。

开发流程大致分为四步:首先,通过audit2allow工具分析审计日志(/var/log/audit/audit.log)提取拒绝访问事件;其次,定义应用程序的类型(如vlock_t)和相关对象类权限;然后,编写策略模块文件(.te)并使用checkmodule编译;最后,通过semodule工具加载模块并测试。

以vlock程序为例,其核心功能是锁定虚拟控制台。开发vlock.pp时,需允许vlock_t进程访问/dev/tty*设备、读取用户会话信息,并阻止其访问无关文件。通过分析审计日志,可发现需要添加的规则包括:allow vlock_t tty_device_t:chr_file { read write };(允许访问终端设备)和allow vlock_t user_session_t:process { signal };(允许发送信号锁定会话)。

开发过程中需注意:避免过度授权(仅分配必要权限)、测试不同运行场景(如用户登录/退出)、使用seinfo工具验证策略规则完整性。对于复杂应用,推荐使用SLIDE(SELinux IDE)工具,其集成了策略编写、编译和调试功能,可显著提升开发效率。

六、SELinux问题诊断与调试技巧

SELinux相关问题的诊断需遵循“先DAC后MAC”的原则。首先确认文件的传统Unix权限(如ls -l)是否正常,排除DAC权限问题后,再检查SELinux策略。常见的SELinux错误会记录在审计日志中,表现为AVC(Access Vector Cache)拒绝消息,例如:type=AVC msg=audit(1690000000.0:100): avc: denied { read } for pid=1234 comm="vlock" path="/etc/passwd" dev="sda1" ino=123 scontext=user_u:user_r:vlock_t:s0 tcontext=system_u:object_r:passwd_file_t:s0 tclass=file permissive=0

分析AVC消息时,需关注四个关键点:源上下文(scontext)、目标上下文(tcontext)、对象类(tclass)和被拒绝的权限(permissions)。例如上述日志表明vlock_t类型的进程试图读取passwd_file_t类型的文件,但策略未允许该操作。解决方法是添加allow vlock_t passwd_file_t:file read;规则,或调整文件的安全上下文(如使用chcon临时修改,或通过semanage fcontext永久设置)。

系统启动过程中若出现文件标签错误(如因重新格式化分区导致标签丢失),可使用restorecon -Rv /path命令恢复默认标签。此外,通过ps -Z查看进程上下文、ls -Z查看文件上下文,可快速定位上下文不匹配问题。

七、SELinux内核驱动与高级技术解析

SELinux内核驱动的核心是LSM框架下的回调函数。LSM定义了约30个安全钩子(Security Hook),覆盖文件操作、进程管理、网络通信等场景。例如,文件打开操作会触发file_open钩子,SELinux在此钩子中检查进程上下文与文件上下文是否允许读取操作。

域转换(Domain Transition)的内核实现涉及execve系统调用的处理。当进程执行新程序时,内核调用bprm_set_creds函数,SELinux通过security_bprm_set_creds钩子检查策略中的类型转换规则,确定新进程的上下文。若规则允许,新进程将以指定的类型运行;否则拒绝执行。

安全上下文与内部标识符(SID, Security Identifier)的映射由内核的selinux_sid_to_contextselinux_context_to_sid函数实现。为提升性能,SELinux维护了一个SID缓存(sidtab),将字符串形式的上下文映射为32位整数SID,减少运行时字符串解析开销。

南京柯普瑞IT学校

南京柯普瑞IT学校
认证 7 年

成立: 2006年

认证 地址认证 教学保障 在线预约 到店体验 售后支持
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-04 14:59:44 HTTP/1.1 GET : http://www.aabqy.com/s/1037/c/43791.html
  2. 运行时间 : 0.076743s [ 吞吐率:13.03req/s ] 内存消耗:405.57kb 文件加载:136
  3. 缓存信息 : 0 reads,0 writes
  1. /data/web/baijiao_branch_collect/public/index.php ( 0.79 KB )
  2. /data/web/baijiao_branch_collect/vendor/autoload.php ( 0.75 KB )
  3. /data/web/baijiao_branch_collect/vendor/composer/autoload_real.php ( 1.63 KB )
  4. /data/web/baijiao_branch_collect/vendor/composer/platform_check.php ( 0.90 KB )
  5. /data/web/baijiao_branch_collect/vendor/composer/ClassLoader.php ( 15.99 KB )
  6. /data/web/baijiao_branch_collect/vendor/composer/autoload_static.php ( 4.26 KB )
  7. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /data/web/baijiao_branch_collect/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /data/web/baijiao_branch_collect/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /data/web/baijiao_branch_collect/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /data/web/baijiao_branch_collect/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /data/web/baijiao_branch_collect/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /data/web/baijiao_branch_collect/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  18. /data/web/baijiao_branch_collect/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  19. /data/web/baijiao_branch_collect/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  20. /data/web/baijiao_branch_collect/app/provider.php ( 0.19 KB )
  21. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  22. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  23. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  24. /data/web/baijiao_branch_collect/app/common.php ( 10.83 KB )
  25. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  26. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  27. /data/web/baijiao_branch_collect/config/app.php ( 1.29 KB )
  28. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  29. /data/web/baijiao_branch_collect/config/cache.php ( 1.22 KB )
  30. /data/web/baijiao_branch_collect/config/config.php ( 0.26 KB )
  31. /data/web/baijiao_branch_collect/config/console.php ( 0.29 KB )
  32. /data/web/baijiao_branch_collect/config/cookie.php ( 0.56 KB )
  33. /data/web/baijiao_branch_collect/config/database.php ( 2.29 KB )
  34. /data/web/baijiao_branch_collect/config/filesystem.php ( 0.63 KB )
  35. /data/web/baijiao_branch_collect/config/lang.php ( 0.81 KB )
  36. /data/web/baijiao_branch_collect/config/log.php ( 1.37 KB )
  37. /data/web/baijiao_branch_collect/config/middleware.php ( 0.19 KB )
  38. /data/web/baijiao_branch_collect/config/route.php ( 1.54 KB )
  39. /data/web/baijiao_branch_collect/config/session.php ( 0.57 KB )
  40. /data/web/baijiao_branch_collect/config/trace.php ( 0.34 KB )
  41. /data/web/baijiao_branch_collect/config/view.php ( 0.81 KB )
  42. /data/web/baijiao_branch_collect/app/event.php ( 0.25 KB )
  43. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  44. /data/web/baijiao_branch_collect/app/service.php ( 0.13 KB )
  45. /data/web/baijiao_branch_collect/app/AppService.php ( 0.26 KB )
  46. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  47. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  48. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  49. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  50. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  51. /data/web/baijiao_branch_collect/vendor/services.php ( 0.14 KB )
  52. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  53. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  54. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  55. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  56. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  57. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  58. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  59. /data/web/baijiao_branch_collect/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  60. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  61. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  62. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.20 KB )
  63. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.75 KB )
  64. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  65. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  66. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.30 KB )
  67. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  68. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  69. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  70. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  71. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  72. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  73. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  74. /data/web/baijiao_branch_collect/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  75. /data/web/baijiao_branch_collect/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  76. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  77. /data/web/baijiao_branch_collect/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  78. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper/Arr.php ( 17.45 KB )
  79. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/cache/driver/Redis.php ( 6.94 KB )
  80. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  81. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  82. /data/web/baijiao_branch_collect/app/Request.php ( 0.09 KB )
  83. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  84. /data/web/baijiao_branch_collect/app/middleware.php ( 0.26 KB )
  85. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  86. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  87. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  88. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  89. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  90. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  91. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  92. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  93. /data/web/baijiao_branch_collect/route/app.php ( 3.05 KB )
  94. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  95. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  96. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  97. /data/web/baijiao_branch_collect/app/controller/Index.php ( 33.26 KB )
  98. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Request.php ( 9.20 KB )
  99. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Url.php ( 14.07 KB )
  100. /data/web/baijiao_branch_collect/app/model/IndexModel.php ( 19.95 KB )
  101. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Config.php ( 1.37 KB )
  102. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Cache.php ( 2.06 KB )
  103. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  104. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.73 KB )
  105. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/PDOConnection.php ( 53.74 KB )
  106. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  107. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  108. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  109. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Builder.php ( 24.07 KB )
  110. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  111. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Query.php ( 15.97 KB )
  112. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  113. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  114. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  115. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  116. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  117. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  118. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  119. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  120. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  121. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  122. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  123. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  124. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  125. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  126. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  127. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  128. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  129. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  130. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/view/driver/Php.php ( 6.44 KB )
  132. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  133. /data/web/baijiao_branch_collect/view/index/pc/school_course_details.php ( 6.12 KB )
  134. /data/web/baijiao_branch_collect/view/index/pc/school_top.php ( 5.76 KB )
  135. /data/web/baijiao_branch_collect/view/index/pc/school_bottom.php ( 1.16 KB )
  136. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000236s ] mysql:host=127.0.0.1;port=3306;dbname=baijiao_branch_collect;charset=utf8
  2. SHOW FULL COLUMNS FROM `fqi_school` [ RunTime:0.000973s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '1037' AND `site_id` = 23 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000337s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000672s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 1037 [ RunTime:0.000227s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000641s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 1037 [ RunTime:0.000230s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000796s ]
  9. SELECT `a`.*,`content` FROM `fqi_school_course` `a` LEFT JOIN `fqi_school_course_content` `b` ON `b`.`content_id`=`a`.`content_id` WHERE `school_id` = 1037 AND `a`.`content_id` = '43791' AND `course_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000710s ]
  10. (select content_id,course_name from fqi_school_course where school_id = '1037' and content_id < '43791' and site_id = '23' order by content_id desc limit 1) union all(select content_id,course_name from fqi_school_course where school_id = '1037' and content_id > '43791' and site_id <= '23' order by content_id asc limit 1) [ RunTime:0.001548s ]
  11. SELECT * FROM `fqi_school_course` WHERE `school_id` = 1037 AND `site_id` = 23 AND `course_status` = 1 AND `school_status` = 1 AND `school_class_id` = 4196 ORDER BY `course_id` DESC LIMIT 4 [ RunTime:0.000454s ]
  12. SELECT * FROM `fqi_school_course` WHERE `school_id` = 1037 AND `site_id` = 23 AND `course_status` = 1 AND `school_status` = 1 ORDER BY `course_id` DESC LIMIT 10 [ RunTime:0.000942s ]
  13. SELECT COUNT(*) AS think_count FROM `fqi_school_course` WHERE `school_id` = 1037 AND `course_status` = 1 [ RunTime:0.000259s ]
  14. SHOW FULL COLUMNS FROM `fqi_school_teacher` [ RunTime:0.000600s ]
  15. SELECT COUNT(*) AS think_count FROM `fqi_school_teacher` WHERE `school_id` = '1037' [ RunTime:0.000210s ]
  16. SHOW FULL COLUMNS FROM `fqi_school_comments` [ RunTime:0.000576s ]
  17. SELECT COUNT(*) AS think_count FROM `fqi_school_comments` WHERE `school_id` = '1037' [ RunTime:0.000202s ]
  18. SELECT `content_id`,`course_name`,`a`.`school_id`,`b`.`school_name` FROM `fqi_school_course` `a` LEFT JOIN `fqi_school` `b` ON `b`.`school_id`=`a`.`school_id` WHERE `a`.`site_id` = '23' AND `b`.`school_status` = '1' AND `course_status` = 1 AND `course_id` < '43791' ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.062675s ]
0.077057s