大型架构及配置技术大数据(二)之完全分布式,节点管理,NFS网关
一、完全分布式
主机名 IP地址 软件 角色
nn60 192.168.4.60/24 HDFS,YARN NameNode SecondaryNameNode ResourceManager
node61 192.168.4.61/24 HDFS,YARN DataNode NodeManager
node62 192.168.4.62/24 HDFS,YARN DataNode NodeManager
node63 192.168.4.63/24 HDFS,YARN DataNode NodeManager
主机名 IP 作用
node4 192.168.4.64/24 新增节点
nfsgw 192.168.4.65/24 浏览访问HDFS文件系统
1)安装部署
1.Hadoop三大核心组件
分布式文件系统HDFS已经部署完毕
分布式计算框架MapReduce
集群资源管理yarn
2.mapred部署
分布式计算框架mapred-site.xml
改名
FROM : mapred-site.xml.template
To : mapred-site.xml
资源管理类
mapreduce.framework.name
分布式计算框架mapred-site.xml
只支持local和yarn两种
单机使用local
集群使用yarn
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
[root@nn60 ~]# cd /usr/local/hadoop/etc/hadoop/
[root@nn60 hadoop]# mv mapred-site.xml.template mapred-site.xml
[root@nn60 hadoop]# vim mapred-site.xml
<configuration>
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
</configuration>
3.yarn部署
资源管理yarn-site.xml
resourcemanager地址
yarn.resourcemanager.hostname
nodemanager使用哪个计算框架
yarn.nodemanager.aux-services
mapreduce_ shuffle 计算框架的名称
mapreduce_ shuffle
资源管理yarn-site.xml
yarn-site.xml配置
<property>
<name>yarn.resourcemanager.hostname</name>
<value>nn60</value>
</property>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
启动服务
# /usr/local/hadoop/sbin/start-yarn.sh
验证服务
jps和./bin/yarn node -list
# ./bin/yarn node -list
[root@nn60 hadoop]# vim yarn-site.xml
<configuration>
<!-- Site specific YARN configuration properties -->
<property>
<name>yarn.resourcemanager.hostname</name>
<value>nn60</value>
</property>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
</configuration>
[root@nn60 hadoop]# for i in 61 62 63;do rsync -aSH /usr/local/hadoop/ 192.168.4.$i:/usr/local/hadoop/ -e 'ssh' & done ==>>同步配置
[1] 5403
[2] 5404
[3] 5405
[root@nn60 hadoop]# ./sbin/start-dfs.sh
[root@nn60 hadoop]# ./sbin/start-yarn.sh
4.Web访问Hadoop
namenode web页面(nn60)
# http://192.168.4.60:50070/
secondory namenode web页面(nn60)
# http://192.168.4.60:50090/
datanode web页面(node61,node62,node63)
# http://192.168.4.61:50075/
resourcemanager web页面(nn60)
# http://192.168.4.60:8088/
nodemanager web页面(node61,node62,node63)
# http://192.168.4.61:8042/
2)HDFS基本使用
1.HDFS使用
HDFS基本命令
# ./bin/hadoop fs -ls /
对应shell命令
#ls /
#./bin/hadoop fs -mkdir /abc
对应shell命令
# mkdir /abc
# ./bin/hadoop fs -touchz /urfile
对应shell命令
# touch /urfile
上传文件
# ./bin/hadoop fs -put localfile /remotefile
下载文件
# ./bin/hadoop fs -get /remotefile
[root@nn60 sbin]# cd /usr/local/hadoop/
[root@nn60 hadoop]# ./bin/hadoop fs -ls / ==>>查看集群问价系统的根,没有内容
[root@nn60 hadoop]# ./bin/hadoop fs -mkdir /aaa ==>>在集群文件系统下创建目录
[root@nn60 hadoop]# ./bin/hadoop fs -ls /
Found 1 items
drwxr-xr-x - root supergroup 0 2020-08-09 07:42 /aaa
[root@nn60 hadoop]# ./bin/hadoop fs -touchz /fa ==>>在集群文件系统下创建fa文件
[root@nn60 hadoop]# ./bin/hadoop fs -put *.txt /aaa ==>>上传*.txt到集群文件系统下的aaa目录
[root@nn60 hadoop]# ./bin/hadoop fs -ls /aaa
Found 3 items
-rw-r--r-- 2 root supergroup 86424 2020-08-09 07:45 /aaa/LICENSE.txt
-rw-r--r-- 2 root supergroup 14978 2020-08-09 07:45 /aaa/NOTICE.txt
-rw-r--r-- 2 root supergroup 1366 2020-08-09 07:45 /aaa/README.txt
[root@nn60 hadoop]# ./bin/hadoop fs -get /aaa ==>>下载集群文件系统的aaa目录
2.Hadoop验证
创建文件夹
# ./bin/hadoop fs -mkdir /input
上传要分析的文件
# ./bin/hadoop fs -put * .txt /input
提交分析作业
# ./bin/Hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.7.7.jar wordcount /input /output
查看结果
# ./bin/hadoop fs -cat output/*
[root@nn60 hadoop]# ./bin/hadoop jar \
> share/hadoop/mapreduce/hadoop-mapreduce-examples-2.7.7.jar \
> wordcount /aaa /bbb ==>>集群分析大数据,hadoop集群/aaa里的数据存到/bbb下
[root@nn60 hadoop]# ./bin/hadoop fs -cat /bbb/* ==>>查看集群里的数据
二、节点管理
1)HDFS节点管理
1.增加节点
HDFS增加结点
启动一个新的系统,设置SSH免密码登录
在所有节点修改/etc/hosts,增加新节点的主机信息
安装java运行环境(java-1.8.0-openjdk-devel)
修改NameNode的slaves文件增加该节点
拷贝NamNode的/usr/local/hadoop到本机
在该节点启动DataNode
./sbin/hadoop-daemon.sh start datanode
HDFS节点管理
设置同步带宽,并同步数据
# ./bin/hdfs dfsadmin -setBalancerBandwidth 60000000
# ./sbin/start balancer.sh
查看集群状态
# ./bin/hdfs dfsadmin -report
[root@node64 ~]# yum -y install java-1.8.0-openjdk-devel
[root@node64 ~]# mkdir /var/hadoop
[root@nn60 ~]# ssh-copy-id 192.168.4.64
[root@nn60 ~]# vim /etc/hosts
192.168.4.60 nn60
192.168.4.61 node61
192.168.4.62 node62
192.168.4.63 node63
192.168.4.64 node64
[root@nn60 ~]# scp /etc/hosts 192.168.4.64:/etc/
[root@nn60 ~]# cd /usr/local/hadoop/
[root@nn60 hadoop]# vim ./etc/hadoop/slaves
node61
node62
node63
node64
[root@nn60 hadoop]# for i in {61..64};do rsync -aSH /usr/local/hadoop/ 192.168.4.$i:/usr/local/hadoop/ -e 'ssh' & done
[root@node64 ~]# cd /usr/local/hadoop/
[root@node64 hadoop]# ./sbin/hadoop-daemon.sh start datanode ==>>启动
[root@node64 hadoop]# jps
2336 Jps
2244 DataNode
[root@node64 hadoop]# ./bin/hdfs dfsadmin -setBalancerBandwidth 60000000
Balancer bandwidth is set to 60000000
[root@node64 hadoop]# ./sbin/start-balancer.sh
[root@nn60 hadoop]# ./sbin/start-yarn.sh
[root@nn60 hadoop]# ssh node64 jps
2560 NodeManager
2672 Jps
2244 DataNode
2.修复节点
修复节点比较简单,与增加节点基本一致
注意:新节点的ip和主机名要与损坏节点的一致
启动服务
# ./sbin/hadoop-daemon.sh start datanode
数据恢复是自动的
上线以后会自动恢复数据, 如果数据量非常巨大,可能需要一定的时间
3.删除节点
配置NameNode的hdfs-site.xml
增加dfs.hosts.exclude配置
<property>
<name>dfs.hosts.exclude</name>
<value>/usr/local/hadoop/etc/hadoop/exclude</value>
</property>
增加exclude配置文件,写入要删除的节点主机名
更新数据
# ./bin/hdfs dfsadmin -refreshNodes
查看状态
# ./bin/hdfs dfsadmin -report
Normal :正常状态
Decommisioned in Program : 数据正在迁移
Decommissioned :数据迁移完成
注意:仅当状态变成Decommisioned才能down机下线
[root@nn60 hadoop]# vim etc/hadoop/slaves ==>>删除节点信息
node61
node62
node63
[root@nn60 hadoop]# vim etc/hadoop/hdfs-site.xml ==>>加入以下内容
<property>
<name>dfs.hosts.exclude</name>
<value>/usr/local/hadoop/etc/hadoop/exclude</value>
</property>
[root@nn60 hadoop]# vim etc/hadoop/exclude
node64
[root@nn60 hadoop]# ./bin/hdfs dfsadmin -refreshNodes
Refresh nodes successful
[root@nn60 hadoop]# ./bin/hdfs dfsadmin -report
Name: 192.168.4.64:50010 (node64)
Hostname: node64
Decommission Status : Decommissioned ==>>显示Decommissioned
[root@node64 hadoop]# ./sbin/hadoop-daemon.sh stop datanode ==>>停止datanode
stopping datanode
[root@node64 hadoop]# ./sbin/yarn-daemon.sh start nodemanager ==>>yarn增加nodemanager
nodemanager running as process 2560. Stop it first.
[root@node64 hadoop]# ./sbin/yarn-daemon.sh stop nodemanager ==>>停止nodemanager
stopping nodemanager
[root@node64 hadoop]# ./bin/yarn node -list ==>>查看节点状态,删除节点,过一段事件才会消失
2)yarn节点管理
由于Hadoop在2.x引入了yarn框架,对于计算节点的操作已经变得非常简单
增加节点
# sbin/yarn-daemon.sh start nodemanager
删除节点
# sbin/yarn-daemon.sh stop nodemanager
查看节点(ResourceManager)
# ./bin/yarn node -list
yarn的系统环境配置与HDFS的基础环境配置是相同的,这里不再重复列出
由于yarn不包含数据, 所以在增加删除修复节点的时候比较简单, HDFS要注意数据安全
三、NFS网关
1)NFS配置
1.NFS网关
NFS网关用途
用户可以通过操作系统兼容的本地NFSv3客户端来浏览HDFS文件系统
用户可以从HDFS文件系统下载文档到本地文件系统
用户可以通过挂载点直接流化数据,支持文件附加,但是不支持随机写
NFS网关支持NFSv3和允许HDFS作为客户端文件系统的一部分被挂载
特性
HDFS超级用户是与NameNode进程本身具有相同标识的用户,超级用户可以执行任何操作,因为权限检查永远不会认为超级用户失败
注意事项
在非安全模式下,运行网关进程的用户是代理用户
在安全模式下, Kerberos keytab中的用户是代理用户
2.配置用户
配置代理用户
在NameNode和NFSGW_上添加代理用户
代理用户的UID , GID, 用户名必须完全相同
如果因特殊原因客户端的用户和NFS网关的用户UID不能保持一致,需要我们配置nfs.map的静态映射关系
nfs.map
uid 10 100 # Map the remote UID 10 the local UID 100
gid 11 101 # Map the remote GID 11 to the local GID 101
在namenode ( nn60 )上添加用户和组
groupadd -g 800 nfsuser
useradd -u 800 -g 800 -r -d /var/hadoop nfsuser
在nfs网关服务器也同样执行以上两条命令
[root@nn60 ~]# vim /etc/hosts
192.168.4.60 nn60
192.168.4.61 node61
192.168.4.62 node62
192.168.4.63 node63
192.168.4.64 node64
192.168.4.65 nfsgw65
[root@nn60 ~]# groupadd -g 800 nfsuser
[root@nn60 ~]# useradd -u 800 -g 800 -r -d /var/hadoop nfsuser
[root@nfsgw65 ~]# groupadd -g 800 nfsuser
[root@nfsgw65 ~]# useradd -u 800 -g 800 -r -d /var/hadoop nfsuser
3.配置core-site.xml
核心配置core-site.xml
hadoop.proxyuser.{代理用户}.groups
hadoop.proxyuser.{代理用户}.hosts
这里的{代理用户}是主机上真实运行的nfs3的用户
在非安全模式下, 运行nfs网关的用户为代理用户
groups为挂载点用户所使用的组
hosts为挂载点主机地址
核心配置core- site.xml
... ...
<property>
<name>hadoop.proxyuser.nfsuser.groups</name>
<value>*</value>
</property>
<property>
<name>hadoop.proxyuser.nfsuser.hosts</name>
<value>*</value>
</property>
... ...
配置步骤
停止集群所有服务
# ./sbin/stop-all.sh
同步配置文件到所有主机
启动hdfs
# ./sbin/start-dfs.sh
[root@nn60 ~]# cd /usr/local/hadoop/
[root@nn60 hadoop]# ./sbin/stop-all.sh ==>>停止所有服务
[root@nn60 hadoop]# cd etc/hadoop/
[root@nn60 hadoop]# >exclude
[root@nn60 hadoop]# vim core-site.xml ==>>添加以下内容
<property>
<name>hadoop.proxyuser.nfsuser.groups</name>
<value>*</value>
</property>
<property>
<name>hadoop.proxyuser.nfsuser.hosts</name>
<value>*</value>
</property>
[root@nn60 hadoop]# for i in {61..63};do rsync -aSH /usr/local/hadoop/ 192.168.4.$i:/usr/local/hadoop/ -e 'ssh' & done
[root@nn60 ~]# /usr/local/hadoop/sbin/start-dfs.sh
[root@nn60 ~]# /usr/local/hadoop/bin/hdfs dfsadmin -report
2)NFSGW配置
1.配置步骤
启动一个新的系统,卸载rpcbind、nfs-utils
配置/etc/hosts ,添加所有NameNode和DataNode的主机名与ip对应关系
安装JAVA运行环境( java-1.8.0-openjdk-devel )
同步NameNode的/usr/local/hadoop到本机
配置hdfs-site.xml
启动服务
2.配置hdfs-site.xml
配置文件hdfs-site.xml
nfs.exports.allowed.hosts
默认情况下, export可以被任何客户端挂载。为了更好的控制访问,可以设置属性。值和字符串对应机器名和访问策略,通过空格来分割。机器名的格式可以是单一的主机、Java的正则表达式或者IPv4地址
使用rw或ro可以指定导出目录的读写或只读权限。
如果访问策略没被提供,默认为只读。每个条目使用";"来分割
hdfs-site.xml配置
nfs.exports.allowed.hosts
配置 * rw
... ...
<property>
<name>nfs.exports.allowed.hosts< /name>
<value>* rw</value>
</property>
... ...
nfs.dump.dir
用户需要更新文件转储目录参数。NFS客户端经常重新安排写操作,顺序的写操作会随机到达NFS网关。这个目录常用于临时存储无序的写操作。对于每个文件,无序的写操作会在他们积累在内存中超过一定阈值(如 ,1M)时被转储。需要确保有足够的空间的目录
如:应用上传10个100M ,那么这个转储目录推荐1GB左右的空间,以便每个文件都发生最坏的情况。只有NFS网关需要在设置该属性后重启
配置文件hdfs-site.xml
nfs.dump.dir
... ...
<property>
<name>nfs.dump.dir</name>
<value>/var/nfstmp</value>
</property>
... ...
配置完该属性后要创建/var/nfstmp文件夹
# mkdir /var/nfstmp
# chown nfsuser.nfsuser /var/nfstmp
并且把该文件夹的属组改成代理用户
3.NFS启动与挂载
启动与挂载
设置/usr/local/hadoop/logs权限,为代理用户赋予读写执行的权限
# setfacl -m user:nfsuser:rwx /usr/local/hadoop/logs
使用root用户启动portmap服务
# ./sbin/hadoop-daemon.sh --script ./ bin/hdfs start portmap
使用代理用户启动nfs3
# sudo -U nfsuser ./sbin/hadoop-daemon.sh --script ./bin/hdfs start nfs3
警告
启动portmap需要使用root用户
启动nfs3需要使用core-site里面设置的代理用户
必须先启动portmap之后再启动nfs3
如果portmap重启了,在重启之后nfs3也需要重启
启动与挂载
目前NFS只能使用v3版本
vers=3
仅使用TCP作为传输协议
proto=tcp
不支持NLM
nolock
禁用access time的时间更新
noatime
禁用acl扩展权限
noacl
强烈建议使用安装选项rsync ,它可以最小化避免重排序写入造成不可预测的吞吐量,未指定同步选项可能会导致上传大文件时出现不可靠行为
启动一台机器并安装nfs-utils
# yum install nfs-utils
挂载nfs
#mount -t nfs -o vers=3,proto=tcp,noatime,nolock,sync,noacl 192.168.4.65:/ /mnt/
[root@nfsgw65 ~]# yum -y install java-1.8.0-openjdk-devel
[root@nn60 ~]# for i in 61 62 63 65;do scp /etc/hosts root@192.168.4.$i:/etc/ ;done
[root@nn60 ~]# rsync -aSH --delete /usr/local/hadoop/ 192.168.4.65:/usr/local/hadoop/ -e 'ssh'
[root@nfsgw65 ~]# mkdir /var/hadoop
[root@nfsgw65 ~]# mkdir /var/nfstmp
[root@nfsgw65 ~]# chown nfsuser:nfsuser /var/nfstmp
[root@nfsgw65 ~]# setfacl -m user:nfsuser:rwx /usr/local/hadoop/logs
[root@nfsgw65 ~]# vim /usr/local/hadoop/etc/hadoop/hdfs-site.xml ==>>添加以下内容
<property>
<name>nfs.exports.allowed.hosts</name>
<value>* rw</value>
</property>
<property>
<name>nfs.dump.dir</name>
<value>/var/nfstmp</value>
</property>
[root@nfsgw65 ~]# su - nfsuser
上一次登录:日 8月 9 09:05:05 CST 2020pts/0 上
-bash-4.2$ cd /var/nfstmp/
-bash-4.2$ touch 1
-bash-4.2$ ls
1
-bash-4.2$ rm -fr 1
-bash-4.2$ ls
-bash-4.2$ cd /usr/local/hadoop/logs/
-bash-4.2$ touch 1
-bash-4.2$ rm -fr 1
[root@nfsgw65 ~]# /usr/local/hadoop/sbin/hadoop-daemon.sh --script /usr/local/hadoop/bin/hdfs start portmap ==>>portmap服务只能用root用户启动
starting portmap, logging to /usr/local/hadoop/logs/hadoop-root-portmap-nfsgw65.out
[root@nfsgw65 ~]# jps
4689 Jps
4649 Portmap
-bash-4.2$ ./sbin/hadoop-daemon.sh --script ./bin/hdfs start nfs3 ==>>nfs3只能用代理用户活动
starting nfs3, logging to /usr/local/hadoop/logs/hadoop-nfsuser-nfs3-nfsgw65.out
-bash-4.2$ jps
4744 Nfs3
4793 Jps
[root@nfsgw65 ~]# jps ==>>root用户执行可以看到portmap和nfs3
4823 Jps
4744 Nfs3
4649 Portmap
[root@node64 ~]# rm -fr /usr/local/hadoop/
[root@node64 ~]# yum -y install nfs-utils
[root@node64 ~]# mount -t nfs -o vers=3,proto=tcp,noatime,nolock,sync,noacl 192.168.4.65:/ /mnt/ ==>>挂载
[root@node64 ~]# cd /mnt/
[root@node64 mnt]# ls
aaa bbb fa system tmp
[root@node64 mnt]# touch a
[root@node64 mnt]# ls
a aaa bbb fa system tmp
[root@node64 mnt]# rm -fr a
[root@node64 mnt]# ls
aaa bbb fa system tmp
[root@node64 mnt]# vim /etc/fstab
192.168.4.65:/ /mnt/ nfs vers=3,proto=tcp,noatime,nolock,sync,noacl,_netdev 0 0
[root@node64 ~]# df -h
文件系统 容量 已用 可用 已用% 挂载点
192.168.4.65:/ 111G 5.2G 106G 5% /mnt
[root@node64 ~]# rpcinfo -p 192.168.4.65
program vers proto port service
100005 3 udp 4242 mountd
100005 1 tcp 4242 mountd
100000 2 udp 111 portmapper
100000 2 tcp 111 portmapper
100005 3 tcp 4242 mountd
100005 2 tcp 4242 mountd
100003 3 tcp 2049 nfs
100005 2 udp 4242 mountd
100005 1 udp 4242 mountd
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 在 Eclipse 和 sublime 中配置与使用 javascript 语法风格检测工具
JSHint(http://www.jshint.com/)是一个JavaScript语法和风格检查工具,你可以用它来提醒代码风格相关的问题。它可以很好地被集成到许多常用的编辑器中,是统一团队编码风格的一个很好的工具。 JSHint Home: http://www.jshint.com/ JSHint Options: http://www.jshint.com/o…...
2024/4/29 3:00:02 - Flume-监控端口数据案例,实时监控单个追加文件案例
文章目录监控端口数据官方案例实时监控单个追加文件 监控端口数据官方案例 1)案例需求: 使用Flume监听一个端口,收集该端口数据,并打印到控制台。 2)需求分析:3)实现步骤: (1)安装netcat工具 [qinjl@hadoop102 software]$ sudo yum install -y nc(3)创建Flume Agen…...
2024/4/29 5:50:10 - shiro自定义Realm
三、SpringBoot整合Shiro完成权限管理案例—自定义Realm使用JdbcRealm可以完成用户权限管理,但是我们必须提供JdbcRealm规定的数据表结构;如果在我们的项目开发中 ,这个JdbcRealm规定的数据表结构不能满足开发需求,该如何处理呢?自定义数据库表结构自定义Realm实现认证和授…...
2024/5/5 16:53:28 - Java学习记录 多线程篇
线程 线程 是进程中的执行过程,一个进程包含有多个线程 进程 是一个运行的应用程序,每个进程都有自己独立的内存空间。在Windows系统中,一个运行的exe(应用程序)就是一个进程 实现线程 实现线程线程主要有 java.lang.Thread类 与 Runnable接口 Thread类Class Thread java.…...
2024/5/5 17:19:54 - 两数组交集
1、给定两个数组,编写一个函数来计算它们的交集。 示例 1: 输入:nums1 = [1,2,2,1], nums2 = [2,2] 输出:[2,2]示例 2: 输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4] 输出:[4,9]方法1:哈希表 public int[] intersect(int[] nums1,int[] nums2) {if(nums1.length>nums2…...
2024/4/29 5:50:01 - idea2020.2显示out和target目录
1.查看model里有没有out和target目录2.查看3.在idea页面进行设置4.结果显示...
2024/4/29 5:49:52 - nested exception is org.apache.ibatis.binding.BindingException: Parameter ‘status‘ not found. Availa
点击看更多解决办法 我的问题 导包时倒错了点击看更多解决办法...
2024/4/29 5:49:48 - thymeleaf 遍历
thymeleaf 遍历...
2024/4/29 5:49:28 - [Ubuntu]Ubuntu16.04安装MySQL8.0
1.去http://dev.mysql.com/downloads/repo/apt/.下载一个mysql-apt-config_0..***_all.deb,使用 sudo dpkg -i mysql-apt-config_0..***_all.deb 安装执行,选择MySQL8.0,OK。 然后apt update一下使用sudo apt install mysql-server命令,就会安装MySQL8.0按此方法会在安装过…...
2024/4/29 5:49:30 - UI设计配色专辑,设计师应用技巧
颜色不仅在设计世界里,在我们生活的世界中都扮演着很重要的角色,一套好的调色板对设计的影响是非常大的,搜UI (SOOUI) 带来更加简单高效的技巧去定义一个色板专辑。产品中大概可以得出一个公式:品牌色 + 提醒类型颜色(成功,错误,警告)+ 中性黑白灰颜色(各种字体,背景…...
2024/4/29 5:49:27 - Visual Studio Code,是一款很好用的文本编辑器,安装扩展后可以大大提高效率。这次来介绍下VS Code远程连接Linux服务器使用docker构建镜像并运行的方法(上)。
Visual Studio Code,简称VS Code,是一款很好用的文本编辑器,安装扩展后可以大大提高效率。这次来介绍下VS Code远程连接Linux服务器使用docker构建镜像并运行的方法。 话不多说,直接开始。 安装VS Code 官网下载:https://code.visualstudio.com/ 安装插件 需要用到以下扩展…...
2024/4/29 5:49:18 - 第四章 element-ui组件 Container 布局容器
一、Container 布局容器<el-container>:外层容器。当子元素中包含 <el-header> 或 <el-footer> 时,全部子元素会垂直上下排列,否则会水平左右排列。<el-header>:顶栏容器。<el-aside>:侧边栏容器。<el-main>:主要区域容器。<el-f…...
2024/4/29 5:49:10 - 蓝桥杯省赛2015——手链样式
【题目】 小明有3颗红珊瑚,4颗白珊瑚,5颗黄玛瑙。 他想用它们串成一圈作为手链,送给女朋友。 现在小明想知道:如果考虑手链可以随意转动或翻转,一共可以有多少不同的组合样式呢? 一开始的错误想法:把圆形手链变成链状,以红色为第一颗珠子。计算十二颗珠子以红色为起点有…...
2024/4/29 5:49:12 - Anaconda创建虚拟环境出现CondaHTTPError: HTTP 000 CONNECTION FAILED for url
Anaconda创建虚拟环境出现CondaHTTPError: HTTP 000 CONNECTION FAILED for url Anaconda的两个核心作用是包管理和版本管理,可以很方便地解决多版本python并存、切换以及各种第三方包安装问题。 学习TensorFlow时无意自动安装了最新的2.X版本,对着1.X版本的教程敲出现了很多…...
2024/4/29 5:49:06 - mysql中可能会遇到的一些问题
修改远程访问权限grant all privileges on *.* to root@% identified by 123456 with grant option; flush privileges;修改密码set global validate_password_policy=0; set global validate_password_length=1; ALTER USER root@localhost IDENTIFIED BY 123456;...
2024/5/3 19:10:44 - javascript 数组的深度复制
此方法存在对古老浏览器的兼容性问题。如确需要作兼容,可引入如下兼容文件解决: https://github.com/douglascrockford/JSON-js/blob/master/json2.js 注意:如果数组值为函数,上述方法还是不行的。 2.2 深度复制的完全实现 考虑到多维数组的嵌套,以及数组值为对象的情况,…...
2024/4/29 5:48:55 - 安全框架Shiro
3.1 认证授权流程认证:对用户的身份进行检查(登录验证)授权:对用户的权限进行检查(是否有对应的操作权限)流程示意图:3.2 安全框架帮助我们完成用户身份认证及权限检查功能框架常用的安全框架:Shiro:Apache Shiro是一个功能强大并且易用的Java安全框架 (小而简单)Sp…...
2024/5/3 23:32:09 - 前端安全看这篇就够了---常见Web攻击第一弹!!!
一、XSS Cross Site Scripting 即我们常说的 跨站脚本攻击!!! XSS (Cross-Site Scripting),跨站脚本攻击,因为缩写和 CSS重叠,所以只能叫 XSS。跨站脚本攻击是指通过存在安全漏洞的Web网站注册用户的浏览器内运行非法的HTML标签或JavaScript进行的⼀种攻击。 跨站脚本攻击…...
2024/4/29 5:48:59 - 20200807作业总结
a.什么是JavaScript,有什么作用,用在什么地方? JavaScript是一门脚本语言,是运行在浏览器中的脚本语言,是由浏览器负责解释执行轻量级的语言 JavaScript代码直接写在HTML网页中 b.JavaScript的发展历史 c.JavaSCript中的数据类型 数字类型 number 字符串类型 string 布尔…...
2024/5/2 1:27:19 - 0808面试
这次猿辅导的面试很糟糕,代码写的很差。这题就是奇偶链表了。 #include<iostream> #include<vector> using namespace std; typedef struct ListNode {int val;ListNode*next;ListNode(int val) :val(val), next(NULL) {} }ListNode;ListNode*fun(ListNode*head) …...
2024/4/29 3:00:17
最新文章
- OceanBase 轻量级数仓关键技术解读
码到三十五 : 个人主页 为了更好地聚合和治理跨域数据,帮助企业用较低的成本快速聚合分析,快速决策,不断的让企业积累的数据产生价值,从全域海量数据抓取,高性能流批处理,元数据血缘治理等等方面…...
2024/5/5 17:32:12 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - Mybatis中sqlSession.getMapper背后的原理
在通过MyBatis操作数据库之前我们一定先通过Session对象获取指定Mappper接口的代理对象。如下代码所示: public class UserMapper{Select(value"SELECT * FROM user")public List<User> findAll(); }public static void main(String [] args){Conf…...
2024/5/3 20:44:41 - javaWeb网上零食销售系统
1 绪 论 目前,我国的网民数量已经达到7.31亿人,随着互联网购物和互联网支付的普及,使得人类的经济活动进入了一个崭新的时代。淘宝,京东等网络消费平台功能的日益完善,使得人们足不出户就可以得到自己想要的东西。如今…...
2024/5/5 8:40:41 - 《c++》多态案例一.电脑组装
一.代码展示 #include <iostream> using namespace std; class CPU { public://抽象计算函数virtual void calculate() 0;};class CVideoCard { public://抽象显示函数virtual void display() 0;}; class Memory { public://抽象存储函数virtual void storage() 0;};…...
2024/5/5 8:48:19 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/5/4 12:05:22 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/5/5 12:22:20 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/5/4 14:46:16 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/5/4 23:54:44 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/5/5 15:25:47 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/5/4 23:54:49 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/5/4 23:54:44 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/5/4 14:46:12 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/5/4 14:46:11 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/5/4 14:46:11 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/5/5 2:25:33 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/5/4 21:24:42 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/5/5 13:14:22 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/5/4 13:16:06 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/5/5 17:03:52 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/5/4 14:46:05 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/5/5 3:37:58 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/5/4 23:54:30 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/5/5 17:03:21 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/5/5 15:25:31 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57