站点动态:欢迎您!今天是 2024-05-14 星期二!
VMware ESXi 6.5上传文件很慢

问题描述

从本机复杂一个6G左右的虚拟硬盘到一台新安装的ESXi6.5,速度奇慢无比,提示需要30分钟。


原因分析

通过搜索,得知是由于VMware在其ESXI 6.5中导入了一个新的SATA驱动vmw-ahci,这个新的驱动相比之前的驱动能够支持更多硬件,但是会引起一些问题。


解决方法

禁用vmw-ahci就好。

VMware ESXi安装群晖DSM6.1

一、环境介绍

1、VMware ESXi 6.5.0 (Build 4887370)

2、黑群晖DSM6.1.7引导由xpenology的大神Jun提供(DS3617xs v1.02b,已转换为vmdk磁盘,文章底部下载列表)

3、DSM 6.1.7-15284(DSM_DS3617xs_15284.pat 官网下载)


二、IMG转换VMDK磁盘

1、打开StarWindConverter.exe,Next

VMware ESXi7.0U2图文安装教程

ESXi7.0U2是由vmware推出的一款虚拟化产品平台,新版本带来了全新的性能,并且采用最新的HTML5技术来管理vsphere client,如果需要客户端管理的请安装6.5.0 (Build 4887370)及其以前版本。现在更多的被用来作为家庭虚拟化,打造All In One,节省设备,利用机器过剩的性能。


这边主要讲讲如何安装ESXi7.0U2(教程使用VMware虚拟机模拟)

一、软件准备

1、ESXi 7.0U2 (VMware-VMvisor-Installer-7.0U2-17630552.x86_64)

2、VMware® Workstation 16 Pro(16.1.0 build-17198959)

HACK emlog程序教程,操作前请先备份。使用memcached缓存来替代文件缓存,毕竟memcached缓存在内存, 文件缓存在硬盘(要看I/O的性能),一般来说内存的性能大于硬盘,所以一般来说memcached缓存优于文件缓存。


memcache相对于文件缓存的优点:

1、读写性能优异,特别是高并发时和文件缓存比有明显优势。

2、memcached组建支持集群,并且是自动管理负载均衡。

HACK emlog程序教程,操作前请先备份。使用Redis缓存来替代文件缓存,毕竟Redis缓存在内存, 文件缓存在硬盘(要看I/O的性能),一般来说内存的性能大于硬盘,所以一般来说Redis缓存优于文件缓存。


Redis相对于文件缓存的优点:

1、读写性能优异,特别是高并发时和文件缓存比有明显优势。

2、Redis支持集群。

Emlog数据库升级程序5.3.1to6.0.0

emlog 6.0.0正式版本的发布,趁着有时间,对自己的博客程序也进行了升级。

对比下emlog5.3.1和emlog6.0.0发现程序变化不大,主要是对tag标签进行了优化。


升级方法:

1、确定程序是emlog5.3.1(本程序是对照5.3.1和6.0.0做的);

2、备份网站系统和数据库(非常重要);

3、下载update.zip(下载地址在文章最后),解压把update.php上传到网站根目录,同config.php同一个目录;

4、浏览器访问update,按照提示输入数据库密码,确认等待升级完成;

emlog文章使用的是blog表中gid自增来作为文章的ID,但是由于后台有删除文章的功能,一旦删除文章那么gid自增就会出现断号。

解决删除导致断号的问题有2种方法:

方法一:不删除文章,采用转为草稿再重新编辑发布的方法,适用于没有删除过文章的。(一般都已经删除文章了才会找到这篇文章)

方法二:只要在添加文章的时候判断gid之前的有没有断号问题,有的话直接插入,没有的话自增。


修改方法

看到emlog BBS有人需要这个代码(emlog统计指定时间内发表的文章数量),所以简单的写一下。

通过log_model.php中的模块函数getLogNum不用自己费力的去写函数了,直接构造数据库查询语句就可以使用这个函数来读取emlog文章数量了。

PS:只要你去研究emlog的核心代码,很多代码都是可以通过emlog自带的核心代码来实现效果的,不用费力不讨好的自己去写数据库查询函数。还能不破坏emlog速度和稳定性。


以下是这段代码,你可以在模版文件的任何地方使用,这个只是简单写一下,当然这个还可以写成函数的格式。建议使用的时候自己改写成函数形式来使用。

Bug描述

今天论坛有人说评论有BUG,我看了一下,无意中注意到isLogCanComment函数。

function isLogCanComment($blogId) { if (Option::get('iscomment') == 'n') { return false; } $query = $this->db->query("SELECT allow_remark FROM ".DB_PREFIX."blog WHERE gid=$blogId"); $show_remark = $this->db->fetch_array($query); if ($show_remark['allow_remark'] == 'n' || $show_remark === false) { return false; }else { return true; } }

以上是isLogCanComment函数的代码,数据库(连接方式使用mysqli)查询$show_remark的值应该是空值NULL,所以不能用===false。

注意:数据库连接方式使用mysqli就会出现这个问题

影响就是POST伪造gid,可以把评论发布到不存在或者未审核未发布的文章下,影响应该不大。