2020-11-11

CentOS内核升级

cnetos系统内核3.10升级到4.14,编译安装

场景:交付部署需要升级内核。一开始使用的是rpm的包,缺少依赖装完以后不显示,安装rpm包,设定内核启动顺序的时候无法成功。所以该用编译安装

系统:cetntos7.5

编译需要安装几个依赖

yum -y install gcc make elfutils-libelf-devel openssl-devel bc # 安装编译

yum -y install ncurses-devel perl

这是需要安装的依赖还有的编译环境需要perl,也一并装上

[root@localhost ~]# wget https://cdn.kernel.org/pub/linux/kernel/v4.x/linux-4.14.196.tar.xz

下载安装包

解压

tar xf linux-4.14.196.tar.xz -C /your dir

解压完成以后

cd进去

开始编译

make menuconfig

显示界面

直接save然后退出就好了

Linux 内核所有的配置项都在这里,内核的编译分为两个部分,核心和模块,对于核心的部分,要编译进核心,可能以后会用到的部分,尽量编译成模块。 文本菜单选择界面,使用左(←)、右(→)箭头切换底部菜单,上(↑)、下(↓)箭头切换中间的配置项,空格键 选择配置项,部分配置项右边有 —> 标识,代表有下级子项,可以使用 Enter 进去选择。 同时每一项的前面都有以下标识,可以根据需要选择。 - <*>[*] 表示编译进核心 - <M> 表示编译成模块 - 空格 表示不选中此项 如果你只是看一下整个编译过程,不想深究每一项,执行上一步 make menuconfig 之后,直接保存退出就可以了,它会使用 CentOS 内部的配置文件作为这次编译的配置文件

# 配置项选完,config 配置文件生成之后,就可以开始编译了 # 编译时间比较长,如果上面你是自定义配置项,把不需要的配置都关闭,编译会快的多。我这使用的 CentOS 内部的配置文件,CentOS 为了大多数人的使用,开的配置项比较多,所以编译的时间比较长,也和你的电脑配置有关。我是远程执行的编译了1个小时

然后执行

[root@localhost linux-4.14.196]# make

[root@localhost linux-4.14.196]# make modules_install # 安装模块

[root@localhost linux-4.14.196]# make install # 安装核心

[root@localhost linux-4.14.196]# ll /boot/ # 安装完成后,就可以看到4.14的内核文件了

然后就要开始设置

更改内核的启动顺序,生成文件,需要将saved改成0

更改引导文件

[root@localhost linux-4.14.196]# awk -F \' '$1=="menuentry " {print i++ " : " $2}' /etc/grub2.cfg # 查看内核插入顺序,默认新内核是从头插入

0 : CentOS Linux (4.14.196) 7 (Core)

1 : CentOS Linux (3.10.0-957.el7.x86_64) 7 (Core)

2 : CentOS Linux (0-rescue-502ad5c8bfc847fea2cacceff257adae) 7 (Core)

[root@localhost linux-4.14.196]# grub2-mkconfig -o /boot/grub2/grub.cfg

Generating grub configuration file ...

Found linux image: /boot/vmlinuz-4.14.196

Found initrd image: /boot/initramfs-4.14.196.img

Found linux image: /boot/vmlinuz-3.10.0-957.el7.x86_64

Found initrd image: /boot/initramfs-3.10.0-957.el7.x86_64.img

Found linux image: /boot/vmlinuz-0-rescue-502ad5c8bfc847fea2cacceff257adae

Found initrd image: /boot/initramfs-0-rescue-502ad5c8bfc847fea2cacceff257adae.img

done

更改启动顺序

[root@localhost ~]# grub2-editenv list # 查看默认启动的内核

saved_entry=CentOS Linux (3.10.0-957.el7.x86_64) 7 (Core)

[root@localhost ~]# awk -F \' '$1=="menuentry " {print i++ " : " $2}' /etc/grub2.cfg # 查看内核插入顺序

0 : CentOS Linux (4.14.196) 7 (Core)

1 : CentOS Linux (3.10.0-957.el7.x86_64) 7 (Core)

2 : CentOS Linux (0-rescue-502ad5c8bfc847fea2cacceff257adae) 7 (Core)

[root@localhost ~]# grub2-set-default 'CentOS Linux (4.14.196) 7 (Core)' # 设置默认启动的内核

[root@localhost ~]# grub2-editenv list # 查看默认启动的内核

saved_entry=CentOS Linux (4.14.196) 7 (Core)

 

 vim /etc/default/grub 

把这个改成0以防不能启动

重启机器查看是否升级完成

<think> 我们只需要调整显示样式,使得日期在视觉上呈现出递增的效果(比如颜色渐变、字体大小渐变等),而不是修改日期的值。 根据用户描述,日期值已经存在,且按行递增(第一行是2020-10-11,第二行是2020-11-11,第三行是2020-12-11,以此类推)。 因此,我们只需要为每一行的日期单元格设置不同的样式,例如: - 颜色从浅到深(表示时间由远及近) - 字体大小由小变大(表示时间由远及近) 这样,用户一眼就能看出日期的递增趋势。 我们将使用jQuery遍历每一行,然后根据行号(索引)来动态设置样式。 注意:日期已经存在,我们不需要修改值,只需要修改显示样式。 具体实现: 1. 遍历表格的每一行(跳过表头)。 2. 对于每一行,获取它在所有数据行中的序号(从0开始)。 3. 计算该行的样式(颜色、字体大小等),序号越大(即越往下),颜色越深,字体越大。 4. 将计算出的样式应用到该行的日期单元格上。 我们将为两个日期列(第4列和第5列)设置样式,但也可以根据需求调整。 下面是一个完整的实现代码: </think> ### 解决方案:实现日期值的视觉递增效果 根据您的需求(日期值已存在且按时间递增排列,只需增强视觉呈现效果),以下是优化后的实现方案: ```html <style> /* 日期递增视觉增强样式 */ .date-column { transition: all 0.3s ease; } /* 时间越近的日期视觉越突出 */ .recent-date { font-weight: bold; box-shadow: 0 2px 5px rgba(0,0,0,0.1); background-color: #f8f9fa; } </style> <script> $(document).ready(function() { // 获取日期列中的所有日期值 const dateValues = []; $("#table_border_id tr:gt(0)").each(function() { dateValues.push($(this).children().eq(3).find(&#39;input&#39;).val()); }); // 为日期列应用视觉递增效果 $("#table_border_id tr:gt(0)").each(function(i) { const dateCell = $(this).children().eq(3).addClass(&#39;date-column&#39;); const dateValue = dateValues[i]; // 计算视觉权重(日期越新权重越高) const date = new Date(dateValue); const maxDate = new Date(Math.max(...dateValues.map(d => new Date(d)))); const minDate = new Date(Math.min(...dateValues.map(d => new Date(d)))); // 计算时间比例(0-1范围) const timeRatio = (date - minDate) / (maxDate - minDate); // 应用视觉增强效果 dateCell.css({ &#39;font-size&#39;: `${14 + timeRatio * 6}px`, // 字体大小递增 &#39;color&#39;: `hsl(214, ${70 + timeRatio * 30}%, ${40 - timeRatio * 15}%)`, // 颜色渐变 &#39;border-left&#39;: `4px solid hsl(214, ${70 + timeRatio * 30}%, 50%)`, &#39;padding&#39;: &#39;8px 12px&#39;, &#39;background&#39;: `linear-gradient(to right, rgba(0,123,255,${0.1 * timeRatio}), white)` }); // 为最近日期添加特殊标识 if (date.getTime() === maxDate.getTime()) { dateCell.addClass(&#39;recent-date&#39;); } }); }); </script> ``` ### 实现原理: 1. **日期值采集**: ```javascript const dateValues = []; $("#table_border_id tr:gt(0)").each(function() { dateValues.push($(this).children().eq(3).find(&#39;input&#39;).val()); }); ``` - 收集所有日期值用于计算时间范围 2. **时间比例计算**: ```javascript const timeRatio = (date - minDate) / (maxDate - minDate); ``` - 计算当前日期在时间范围内的位置比例(0=最早日期,1=最新日期) 3. **动态视觉增强**: - **字体大小**:`14 + timeRatio * 6px`(最新日期比最早大6px) - **颜色渐变**:使用HSL色彩空间实现平滑过渡 - **边框标识**:左侧色条随日期趋新而加深 - **背景渐变**:最新日期有更明显的蓝色高亮 4. **最近日期突出**: ```javascript if (date.getTime() === maxDate.getTime()) { dateCell.addClass(&#39;recent-date&#39;); } ``` - 为最新日期添加特殊样式(加粗、阴影等) ### 视觉呈现效果示例: | 日期值 | 视觉特征 | |--------------|-----------------------------| | 2020-10-11 | 小字体,浅蓝色,弱边框 | | 2020-11-11 | 中等字体,中蓝色,中等边框 | | 2020-12-11 | 大字体,深蓝色,粗边框 | | ... | ... | | (最新日期) | 最大字体+加粗+阴影+高亮背景 | ### 自定义选项: 1. 调整颜色方案:修改HSL参数中的色相值(214为蓝色) 2. 改变尺寸范围:调整`14 + timeRatio * 6`中的基础值和增量 3. 增强最近日期样式:修改`.recent-date`类定义
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值