Windows系统XAMPP安装Moodle教程
一.安装工具下载:
系统环境:
operating system: windows 10 enterprise 64-bit (10.0, build 17134)
集成软件:
xampp version: 7.2.10,xampp主要就是搭建apache服务器和mysql数据库。xampp(apache+mysql+php+perl)是一个功能强大的建站集成软件包。当然你也可以使用easy php或者wamp或帝国软件,这些都是集成包。你要是不想使用的话可以自己单独安装后自己配置。这里我使用xampp 7.2.10。
xampp最新版下载地址:https://www.apachefriends.org/index.html
安装moodle 3.5.2的要求: php 7.0, mariadb 5.5.31 or mysql 5.5.31 or postgres 9.3 or mssql 2008 or oracle 10.2
moodle下载:
moodle最新版下载地址:https://download.moodle.org/releases/latest/
moole 3.5.2+ : 后面的+表示moodle是稳定版
如果要使用和我一样的版本的话,使用下面的下载地址:
链接:https://pan.baidu.com/s/1b0j2mlhdz1gzrxrirvhfna
提取码:tg73
二.安装环境配置:
由于我的电脑上已经有iis服务器了,iis服务器使用的是80端口,你如果安装apache的话也会使用80端口,这样会造成冲突,所以我们需要配置iis的端口。当然你的电脑上没有iis的话不用执行下面的步骤:
1.使用windows+r打开运行,输入compmgmt.msc 打开计算机管理
2.定位到iis管理,点击关闭
3.点击绑定,修改端口
4.点击开始,然后在浏览器中输入localhost:81,可以看到已经可以访问到iis了,这样端口就修改完成了。
三.开始安装
1.xampp安装:
这里是让你不要安装到c:\program files(x86)文件夹下,因为它没有安装权限。uac就是
我这里安装到了d:\xampp,之后就一直下一步就行
安装完后,打开d:\xampp\xampp-control.exe
这里一定要保证apache和mysql是绿色的才可以安装后面的步骤。
apache启动常见错误
1.1有其他程序在占用80端口,你直接netstat找到占用端口的程序后,启动任务管理器,找到对应的程序结束后就可以。
1.2有其他程序占用80端口,任务管理器结束不了的话修改apache的监听端口为82,然后重启apache服务器。
注意:如果在这里修改为82端口后,之后访问apache的地址为: localhost:82 没有修改的话直接 localhost 就可以
当你在浏览器中输入localhost后可以看到这个界面时表示apache已经正确安装
mysql启动常见错误:
以前安装过mysql57或mysql,没有卸载干净。
1.在环境变量path中将mysql删除
2.管理员运行cmd,cd 到d:\xampp\mysql\bin
输入sc query mysql,查看一下名为mysql的服务:
发现之前确实有安装过。
命令sc delete mysql,删除该mysql
输入安装命令mysqld install
此时,查看xampp-control.exe就可以发现mysql的服务就正常启动了
2.moodle安装
将下载的moodle-latest-35.zip解压后,拷贝其中的moodle文件夹到d:\xampp\htdocs
将下载的语言包zh_cn.zip解压后拷贝到d:\xampp\htdocs\moodle\lang下
在浏览器地址栏(之后默认都是在地址栏中输入)中输入localhost/moodle 如果你之前改过apache的端口为82 ,则这里应该输入localhost:82/moodle
直接一直next:
到了这一步会有以下错误:
这里写下这些错误的解决方法(你也可以直接点击后的文字查看官方的文档,此时你必须在第一步选择英文安装才能看到官方的英文文献),不想看的看我的解决方法:
2.1wrong $cfg->dbtype
: you need to change it in your config.php
file, from 'mysql
' to 'mariadb
'.
修改d:\xampp\htdocs\moodle\config.php
$cfg->dbtype = 'mariadb';
2.2需要 intl 扩展改善国际化支持,例如与语言区适应的排序及国际域名。
(intl extension is required to improve internationalization support, such as locale aware sorting and international domain names.)
网页服务及moodle网络功能需要 xmlrpc 扩展。
(the xmlrpc extension is useful for web services and moodle networking.)
网络服务和某些插件需要安装可选的 soap 扩展。
(installing the optional soap extension is useful for web services and some plugins.)
修改d:\xampp\php\php.ini 将intl,xmlrpc,soap前面的分号去掉
2.3php字节码缓存提高性能且降低对内存的要求。moodle完全支持并建议使用opc缓存扩展
(php opcode caching improves performance and lowers memory requirements, opcache extension is recommended and fully supported.)
修改d:\xampp\php\php.ini 查找到[opcache]所在的位置添加以下代码
[opcache] opcache.enable = 1 opcache.memory_consumption = 128 opcache.max_accelerated_files = 10000 opcache.revalidate_freq = 60
; required for moodle opcache.use_cwd = 1 opcache.validate_timestamps = 1 opcache.save_comments = 1 opcache.enable_file_override = 0
zend_extension=opcache.so
; if something does not work in moodle ;opcache.revalidate_path = 1 ; may fix problems with include paths ;opcache.mmap_base = 0x20000000 ; (windows only) fix opcache crashes with event id 487 ; experimental for moodle 2.6 and later ;opcache.fast_shutdown = 1 ;opcache.enable_cli = 1 ; speeds up cli cron ;opcache.load_comments = 0 ; may lower memory use, might not be compatible with add-ons and other apps.
然后,在php.ini的文档的最末尾添加
[extensionlist] zend_extension=php_opcache.dll
2.4您的数据库在使用 antelope 作为文件格式。在mysql和mariadb实现完全 utf-8 支持需要使用 barracuda 文件格式。请切换至 barracuda 文件格式。详见以下文档mysql full unicode support(your database uses antelope as the file format. full utf-8 support in mysql and mariadb requires the barracuda file format. please switch to the barracuda file format. see the documentation mysql full unicode support for details.)
为了能完整支持 utf-8 ,mysql 和 mariadb 两者都需要您把您的 mysql 配置 \'innodb_file_per_table\' 为 \'on\'。请参考文档以便了解细节(for full support of utf-8 both mysql and mariadb require you to change your mysql setting 'innodb_large_prefix' to 'on'. see the documentation for further details.)
修改d:\xampp\mysql\bin|\my.ini 分别在对应位置添加下列代码
[client] default-character-set = utf8mb4 [mysqld] innodb_file_format = barracuda innodb_file_per_table = 1 innodb_large_prefix character-set-server = utf8mb4 collation-server = utf8mb4_unicode_ci skip-character-set-client-handshake [mysql] default-character-set = utf8mb4
antelope和barracuda均为innodb存储引擎的文件格式,antelope为默认格式,非压缩;barracuda为压缩格式;两者主要的不同在于对大数据量的存储时所占用的空间差异。
若要使用innodb的压缩功能,则必须使用innodb_file_format=barracuda,不然没有作用。
2.5已经检测到你的网站没有使用 https 来增加安全。强烈建议您将您的网站改用https 以增加安全性,并改进与其他系统的整合。(it has been detected that your site is not secured using https. it is strongly recommended to migrate your site to https for increased security and improved integration with other systems.)
这个是让你安装ssl 证书,就是提供https的访问,我这里不需要,这个问题可以跳过不用修改,需要的查看 https://docs.moodle.org/35/en/transitioning_to_https
在解决完以上问题后,在xampp-control重启apache和mysql服务,然后点击浏览器页面最下面的重新加载按钮
如果重新加载后出现以下画面表示可以继续
如果还是出现2.4的问题,那么你要执行以下命令:
以管理员身份启动cmd,定位到d:\xampp\mysql\bin下
mysql -u root -p
表示以root身份登录到mysql
show global variables like "innodb_file_format%"; set global innodb_file_format=barracuda; set global innodb_large_prefix=on; set global innodb_file_format_max=barracuda; show global variables like "innodb_file_format%";
然后重新启动mysql服务,然后重新加载页面就可以。
点击继续安装:
出现这个界面,说明正在开始安装,你要等好一会。安装完后继续:
这几个红色的为必填项,是设置你一会要登录的管理员账号,一定要记住。其他信息自己填,不填也可以,然后继续。这里有点慢,大家要等一会。
在这里等一会之后如果出现登录页面则表示正常。如果一直是空白页面你则需要进行以下步骤:
(1)在d:\xampp\php\php.ini文件中,
;open_basedir =
这句是注释掉的,改为(xampp集成安装路径)如下:
open_basedir = "d:\xampp"
open_basedir用来限制网站文件访问路径
(2)d:\xampp\moodledata这个文件夹本来在moodle外,需要将其移动到d:\xampp\htdocs\moodle下
修改在d:\xampp\htdocs\moodle\config.php文件中
$cfg->dataroot = 'd:\\xampp\\htdocs\\moodle\\moodledata';
这两步处理好后,在浏览器输入localhost/moodle/admin/index.php,访问不会空白了,但是出现如下问题:
fatal error: maximum execution time of 30 seconds exceeded in d:\xampp\htdocs\moodle\lib\classes\component.php on line 752
这是因为你的上面修改config.php中的$cfg->dataroot 后面的路径中丢了\\,这里是 \\ 不是 \,重新修改刷新后就会出现下面问题
warning: is_readable(): open_basedir restriction in effect. file(/db/renamedclasses.php) is not within the allowed path(s): (d:\xampp) in d:\xampp\htdocs\moodle\lib\classes\component.php on line 1236
修改如下:
d:\xampp\htdocs\moodle\admin目录下index.php文件里有如下代码段:
if ((isset($_get['cache']) and $_get['cache'] === '0') or (isset($_post['cache']) and $_post['cache'] === '0') or (!isset($_post['cache']) and !isset($_get['cache']) and empty($_get['sesskey']) and empty($_post['sesskey']))) { // prevent caching at all cost when visiting this page directly, // we redirect to self once we known no upgrades are necessary. // note: $_get and $_post are used here intentionally because our param cleaning is not loaded yet. // note2: the sesskey is present in all block editing hacks, we can not redirect there, so enable caching. define('cache_disable_all', true); // force opcache reset if used, we do not want any stale caches // when detecting if upgrade necessary or when running upgrade. if (function_exists('opcache_reset')) { opcache_reset(); } $cache = 0; } else { $cache = 1; }
这段代码为检测moodle是否有缓存信息和关键数据保护检测。会根据不同的情况给cache字段赋值。
(1)将这段代码注释或删除掉,使得moodle平台在第一次安装后进入该页面不去考虑cache值的设置,而直接进入平台的主页面。
(2)在目录栏内输入localhost/moodle/index.php?cache=1。然后对平台进行操作时,数据库和缓存中会有新生成数据的写入。 之后再输入http://localhost/moodle/admin/user.php进入登陆界面
当然,你也可以换成中文。
(3)此时再在index.php文件中恢复上述注释或删除的代码段。再次打开moodle平台时,检测机制会顺利的通过,而不会出现因检测语句冗余而产生的页面重定向循环问题。
至此,moodle安装成功!!!
最后,提供moodle官网下载插件的链接:
https://moodle.org/plugins
插件安装方法:
https://docs.moodle.org/all/zh/index.php?title=%e5%ae%89%e8%a3%85%e6%8f%92%e4%bb%b6&variant=zh
参考网址:
https://blog.csdn.net/shiyongchun8212/article/details/83415585
https://blog.csdn.net/zcyzsy/article/details/52012664
https://blog.csdn.net/wll_1017/article/details/54860881
https://www.jb51.net/article/52530.htm
推荐阅读
-
Windows7旗舰版32位Oracle10g的安装和卸载教程
-
在Windows XP系统安装SQL server 2000 企业版(图解版)
-
Windows 8下MySQL Community Server 5.6安装配置方法图文教程
-
Windows10下mysql 5.7.21 Installer版安装图文教程
-
Windows8下mysql 5.6.15 安装配置方法图文教程
-
Windows10下mysql 8.0.12 解压版安装图文教程
-
Windows下python2.7.8安装图文教程
-
在Mac OS系统上安装Python的Pillow库的教程
-
Windows环境下安装PHP Pear的方法图文教程
-
mysql 5.7.17 免安装版配置方法图文教程(windows10)