保护Predix机器安全

2023-10-12 22:20
文章标签 安全 机器 保护 predix

本文主要是介绍保护Predix机器安全,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

保护Predix机器安全
由于Predix机器支持多种部署,提供一个确保其安全的综合指南是不切实际的。解决方案至少应执行这些推荐的步骤。
1. 保护/security文件夹。
2. 修改KeyStore和TrustStore密码。
3. 发布证书。
4. 确保技术人员控制台安全,在首次登录时修改密码。
保护安全文件夹
必须对Predix机器安全文件夹进行保护,确保只有一名具有特殊权限的用户可以读取该文件夹的内容。
Predix机器的/security文件夹含有敏感信息,例如密码和具有私钥的KeyStore。至少需要对该文件夹进行完整保护,确保只有一名具有最低权限的用户可以读取该文件夹的内容。这样可以确保系统中其他用户均无法读取安全文件夹的内容。对于可以访问安全文件夹的用户,确保限制其对系统进行更深入的访问。
以下是如何保护安全文件夹的一个示例。
1. 创建一个称为predixuser的用户,作为您自己的操作系统中一般用户组的一部分。该用户不是管理员或根用户。
2. 将/security文件夹的所有控制(读取、写入、执行)修改为只有新用户可以访问。
3. 以具有有限权限的用户的身份运行Predix机器。
重要提示:
避免以根用户/管理员的身份运行Predix机器。如果您必须以根用户/管理员的身份运行,确保限制对根用户/管理员账户访问的权限。
修改KeyStore和TrustStore密码
修改KeyStore和TrustStore密码
如果要确保Predix机器安全,您应该修改KeyStore和TrustStore密码。
• 安全管理服务使用的许多KeyStore已生成密码,应视为安全。为客户端和服务器TLS、数字签名和密钥生成的KeyStore已生成密码。密码在/security/com.ge.dspmicro.securityadmin.cfg处的安全管理配置文件中。
有些密码未生成,应修改。
• TrustStore密码未生成,应立即修改。
1. 立即修改OPC-UA客户端和OPC-UA服务器的KeyStore,因为其各自配置文件中的密码难以恢复。
注:
参见配置OPC-UA适配器和配置OPC-UA服务器。
2. 在/security文件夹中修改TrustStore密码。
注:
参见配置客户端KeyStore/TrustStore和配置服务器KeyStore/TrustStore。
发布证书
发布证书
Predix机器为其不同keystore生成多个自签名证书。可以使用这些证书建立TLS连接,但是浏览器不信任这些证书,因为它们未经过可信根证书颁发机构(CA)签名。
如果需要正确签名的证书,您必须获取由CA发布的证书。
1. 获取由CA发布的证书。
2. 通过配置服务器KeyStore/TrustStore将该证书导入/security/tls_server_keystore.jks处的服务器SSLContext KeyStore。
首次登录时,修改Predix机器技术人员控制台的密码。
确保技术人员控制台安全
技术人员控制台提供对Predix机器的管理控制。在设置新的Predix机器实例时您应该确保控制台的安全。
1. 使用CA签名的证书。
a. 获取签名的证书。
b. 将该证书导入/security /tls_server_keystore.jks文件中。参见导入新的私钥和CA签名证书
c. 配置服务器SSLContext keystore。Predix机器技术人员控制台使用安全管理keystore中提供的证书建立TLS。
2. 修改Predix机器技术人员控制台密码。
a. 选择Predix > 用户管理。
b. 选择默认用户。
c. 输入一个新密码。
3. Predix机器的设置完成后,禁用技术人员控制台,以防止访问。您可以禁用和启用技术人员控制台的使用:禁用命令在EdgeManager中。参见执行命令。
如果未来需要访问,你必须重新将其启用。
Predix机器VPN服务
Predix机器提供一项管理VPN客户端的服务,以便提供与预期服务器目的地址的安全连接。
使用Predix机器VPN服务之前您必须准备好具有要通信的服务器和客户端的环境。
Predix机器通过使用VPN的管理工具提供其证书和密钥,用于VPN客户端和服务器之间的HTTP通信。这就允许Predix机器保留其私钥并提供一个签署VPN通信所需请求的API。
注:
由于请求签名由Predix机器执行,您必须引入PredixConnectivity相关的人员设计出一个可行的配置方案,其中应考虑到证书颁发机构和目的服务器的设置。
Predix连接用例
该用例示例展示现场设备上运行的Predix机器,该设备通过证书注册在Predix EdgeManager中注册。VPN服务器设置为识别由证书颁发机构颁发给Predix机器的证书,EdgeManager使用该证书进行设备注册。还会将VPN服务器设置为信任相同的证书颁发机构。因此,当VPN客户端请求Predix机器为信息签名时,所用的私钥和证书已通过服务器信任。
根据需求不同其他用例可能会不同。
功能
1. 在com.ge.dspmicro.predix.connectivity.openvpn.config文件中配置VPN目录设定值。
2. 注册设备。
3. Predix连接捆绑包为VPN客户端提供公共证书,在设备注册后提交给服务器。
4. 必须在VPN客户端启动之前提供VPN客户端的证书,否则,它会出错结束。一旦证书可用,VPN客户端就可以启动。
5. 然后,它打开一个TCP通信套接字进入等待模式,直到有管理客户端对其进行管理。
6. 如果Predix机器正在运行而且连接VPN管理配置开关被启用,它将作为管理客户端,回答VPN客户端的签名请求,以启用安全连接。
VPN成功连接的证据是在网络接口中看到TUN/TAP设备。
限制
• 当前的VPN管理仅用于Linux环境。
• VPN的配置与平台无关,也可能与OS版本无关。
• 2.3.12之前的VPN版本有bug会导致管理接口不可用。
配置VPN
配置VPN目录的设定值。
1. 导航至/configuration/machine。
2. 打开com.ge.dspmicro.predix.connectivity.openvpn.config文件,设置以下属性的值:
图片描述
图片描述
图片描述
图片描述

  1. 格式化.config文件(不是.cfg文件)内的属性值时,使用类型字符,后跟引用的值字符串表示。例如,一个布尔型属性=B”true”。小写类型字符表示基本数据。字符串的类型可以省略。下表列出了类型和对应的类型字符:
    图片描述
  2. 数组格式为属性=<类型>[”<值1>”,”<值2>”]。例如,整型数组属性=I[“1”, “2”, “3”].清晰起见,可使用反斜杠分隔。
    获取VPN日志示例
    ILogsHandler服务接口设计为与Predix机器和EdgeManager日志目录以及检索系统一起使用。
    ILogsHandler服务接口使VPN日志可用于GetLog和GetAvailableLogs命令,这些命令已经在Predix机器中可用。
    • GetLog – 将一个用户特定日志文件上传到Edgemanager。
    • GetAvailableLogs – 检索您为GetLog命令给定的日志的文件名。
    示例:
    public String[] getLogFileNames(); /* @param logFileName - the filename for which to get content for.It should be a name that was given by getLogFileNames().* @return - an InputStream from which log content may be read.* * It is up to the implementation to handle file permission issues for log files that are stored in restricted portions of * the device storage, as well as the reading of files that are perhaps being written to as they are read.*/ public InputStream getLogContent(String logFileName); }

这篇关于保护Predix机器安全的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/minmin0/article/details/80130283
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/198830

相关文章

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

浅析Java如何保护敏感数据

《浅析Java如何保护敏感数据》在当今数字化时代,数据安全成为了软件开发中至关重要的课题,本文将深入探讨Java安全领域,聚焦于敏感数据保护的策略与实践,感兴趣的小伙伴可以了解下... 目录一、Java 安全的重要性二、敏感数据加密技术(一)对称加密(二)非对称加密三、敏感数据的访问控制(一)基于角色的访问

JAVA保证HashMap线程安全的几种方式

《JAVA保证HashMap线程安全的几种方式》HashMap是线程不安全的,这意味着如果多个线程并发地访问和修改同一个HashMap实例,可能会导致数据不一致和其他线程安全问题,本文主要介绍了JAV... 目录1. 使用 Collections.synchronizedMap2. 使用 Concurren

Python从零打造高安全密码管理器

《Python从零打造高安全密码管理器》在数字化时代,每人平均需要管理近百个账号密码,本文将带大家深入剖析一个基于Python的高安全性密码管理器实现方案,感兴趣的小伙伴可以参考一下... 目录一、前言:为什么我们需要专属密码管理器二、系统架构设计2.1 安全加密体系2.2 密码强度策略三、核心功能实现详解

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

客户案例:安全海外中继助力知名家电企业化解海外通邮困境

1、客户背景 广东格兰仕集团有限公司(以下简称“格兰仕”),成立于1978年,是中国家电行业的领军企业之一。作为全球最大的微波炉生产基地,格兰仕拥有多项国际领先的家电制造技术,连续多年位列中国家电出口前列。格兰仕不仅注重业务的全球拓展,更重视业务流程的高效与顺畅,以确保在国际舞台上的竞争力。 2、需求痛点 随着格兰仕全球化战略的深入实施,其海外业务快速增长,电子邮件成为了关键的沟通工具。