header.setContentDispositionFormData("attachment;filename*=UTF-8''", fileName);无法设

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了header.setContentDispositionFormData("attachment;filename*=UTF-8''", fileName);无法设相关的知识,希望对你有一定的参考价值。

一直是默认的,无法设置文件名

参考技术A header.setContentDispositionFormData("attachment;filename*=UTF-8''"+fileName);

03ThingsBoard-ThingsBoard安装

1、Windows下编译安装

1.1、概述

很多的人反馈在Windows环境下安装thingsboard总是编译不过,其实大家的环境基本上问题都不大,因为thingsboard需要对前端进行install,然后生成node_modules文件,因为这里面需要去外网下载很多的东西,很多人的网络不好,就会导致报错,基本上都是网络导致的,目前thingsboard的jdk版本需要11了,这是前提,其它的版本只要比我文档的高基本上都没有问题,具体的安装细节,在网上搜一下一大堆

1.2、安装jdk

C:\\Users\\Administrator>java -version
java version "11.0.12" 2021-07-20 LTS
Java(TM) SE Runtime Environment 18.9 (build 11.0.12+8-LTS-237)
Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.12+8-LTS-237, mixed mode)

1.3、安装maven(maven中的jdk一定要一样哦)

C:\\Users\\Administrator>mvn -v
Apache Maven 3.6.3 (cecedd343002696d0abb50b32b541b8a6ba2883f)
Maven home: D:\\yuxinwei\\java\\apache-maven-3.6.3\\bin\\..
Java version: 11.0.12, vendor: Oracle Corporation, runtime: D:\\yuxinwei\\java\\jdk-11.0.12
Default locale: zh_CN, platform encoding: GBK
OS name: "windows 10", version: "10.0", arch: "amd64", family: "windows"

1.4、Node版本

C:\\Users\\Administrator>node -v
v14.12.0

1.5、npm版本

C:\\Users\\Administrator>npm -v
6.14.8

1.6、yarn版本

C:\\Users\\Administrator>yarn -v
1.22.11

1.7、新建thingsboard-3.4.2文件夹,并进入

1.8、进入thingsboard-3.4.2目录然后拉取代码

git clone -b v3.4.2 https://github.com/thingsboard/thingsboard

1.9、在进入到thingsboard目录下,使用cmd进入命令行窗口,执行

mvn clean install -DskipTests

如果中途报错,就反复执行命令,95%都是网络差原因导致报错。

1.10、将工程使用IDEA打开,配置maven环境以及jdk环境

1.11、安装postgres,版本大于11

docker run -d --name postgres -p 5432:5432 -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=test123456 -v ~/docker_data/pgsql/data:/var/lib/postgresql/data postgres:12
注意:
POSTGRES_PASSWORD:密码需要设置自己规定的密码

1.12、在Navicate创建thingsboard3.4.2数据库

新建数据库 thingsboard3.4.2,然后修改thingsboard程序中的 thingsboard.yml 中的数据库连接的名字也叫 thingsboard3.4.2,同时修改自己安装PG的密码。

使用Navicate连接PG,然后新建thingsboard3.4.2,需要注意的是如果Navicate的版本太低了,可能会报错,尽量版本高一点,我目前使用的是Navicate15。

然后修改thingsboard的application.yml文件,使用ctrl + f 搜索jpa,就可以找到如下图位置,进行配置数据的相关信息。

1.13、将程序dao模块下的sql文件夹拷贝到application模块的data目录下

1.14、启动ThingsboardInstallApplication进行安装表结构

如果启动报错显示如下

需要修改:

然后在重新启动就成功了,最后查看thingsboard3.4.2是否生成表结构

1.15、启动ThingsboardServerApplication服务

如果启动报错显示如下

需要修改:

1.16、访问 http://localhost:8080/login

欢迎加扣群594880091 

2、Linux环境下Docker-Compose安装

1、环境准备

我平时都是使用window本地编译安装用于本地开放或者研究源码,同时也在Linux服务上直接使用Docker-Compose快速拉起一个thingsboard服务,目前我使用的是centos,有些使用Ubuntu,大同小异。

安装Docker

环境查看

# 系统内核是3.10以上
[root@aldricheugene /]# uname -r
3.10.0-514.26.2.el7.x86_64
# 系统版本
[root@aldricheugene /]# cat /etc/os-release 
NAME="CentOS Linux"
VERSION="7 (Core)"
ID="centos"
ID_LIKE="rhel fedora"
VERSION_ID="7"
PRETTY_NAME="CentOS Linux 7 (Core)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:centos:centos:7"
HOME_URL="https://www.centos.org/"
BUG_REPORT_URL="https://bugs.centos.org/"
CENTOS_MANTISBT_PROJECT="CentOS-7"
CENTOS_MANTISBT_PROJECT_VERSION="7"
REDHAT_SUPPORT_PRODUCT="centos"
REDHAT_SUPPORT_PRODUCT_VERSION="7"

帮助文档

https://docs.docker.com/engine/install/centos/

安装流程

# 1、卸载旧的版本
sudo yum remove docker \\
                  docker-client \\
                  docker-client-latest \\
                  docker-common \\
                  docker-latest \\
                  docker-latest-logrotate \\
                  docker-logrotate \\
                  docker-engine

# 2、需要的安装包
sudo yum install -y yum-utils

# 3、设置镜像的仓库,默认是从国外的,不推荐
sudo yum-config-manager \\
    --add-repo \\
    https://download.docker.com/linux/centos/docker-ce.repo

# 推荐使用国内的
sudo yum-config-manager \\
		--add-repo \\
		https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

# 4、更新yum软件包索引
sudo yum makecache fast

# 5、安装docker相关的  docker-ce 社区版  ee 企业版
yum install -y docker-ce docker-ce-cli containerd.io

# 6、启动docker
systemctl start docker

# 7、设置开机启动
systemctl enable docker

# 8、使用docker version查看是否安装成功
docker version

安装Docker-Compose

下载

国外:
sudo curl -L "https://github.com/docker/compose/releases/download/1.28.6/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

国内:
sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.24.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

赋予权限

sudo chmod +x /usr/local/bin/docker-compose

验证

docker-compose --version

2、创建目录

[root@aldricheugene ~]# cd
[root@aldricheugene ~]# mkdir thingsboard
[root@aldricheugene ~]# cd thingsboard/

3、创建docker-compose.yml

进入到自己创建的thingsboard目录下,创建一个docker-compose.yml文件

[root@aldricheugene thingsboard]# touch docker-compose.yml

4、编写docker-compose.yml文件

官方文档

https://thingsboard.io/docs/user-guide/install/docker/

安装类型选择

官方根据所使用的数据库,提供了三种类型的 ThingsBoard 单实例 docker 镜像:

  • thingsboard/tb-postgres:带有 PostgreSQL 数据库的 ThingsBoard 的单个实例。具有至少 1GB RAM 和最小负载(每秒几条消息)的小型服务器的推荐选项。推荐 2-4GB(个人玩推荐使用)。
  • thingsboard/tb-cassandra:ThingsBoard 与 Cassandra 数据库的单个实例。性能最高且推荐的选项,但需要至少 4GB 的 RAM,推荐 8GB。(公司少量设备推荐使用)
  • thingsboard/tb:带有嵌入式 HSQLDB 数据库的 ThingsBoard 的单个实例(不推荐使用)。

队列选择

ThingsBoard 能够使用各种消息系统来存储 ThingsBoard 服务之间的消息和通信:

  • In Memory:内存队列实现是内置的和默认的。它对开发 (PoC) 环境很有用,不适合生产部署或任何类型的集群部署。
  • Kafak:这个队列现在用于大多数 ThingsBoard 生产环境。它对本地部署和私有云部署都很有用,需要根据公司的业务量来选择,而且需要有人懂kafka,不然生产环境遇到问题就很难解决。
  • RabbitMQ:如果业务负载不是很大,并且你已经使用过这个消息系统,那么推荐使用RabbitMQ

其他的一些第三方的我就不描述了,如果是自己玩或者设备很少使用内存队列足够了,如果是业务量一般大就使用RabbitMQ,业务量非常大使用Kafka集群。

编写配置

如果选择【thingsboard/tb-postgres + In Memory】来安装(个人或者设备量很少使用)

version: '3.0'
services:
  mytb:
    restart: always
    image: "thingsboard/tb-postgres"
    ports:
      - "8080:9090"
      - "1883:1883"
      - "7070:7070"
      - "5683-5688:5683-5688/udp"
    environment:
      TB_QUEUE_TYPE: in-memory
    volumes:
      - ~/.mytb-data:/data
      - ~/.mytb-logs:/var/log/thingsboard

如果选择【thingsboard/tb-postgres + Kafka】来安装(设备量多的情况)

version: '3.0'
services:
  zookeeper:
    restart: always
    image: "zookeeper:3.5"
    ports:
      - "2181:2181"
    environment:
      ZOO_MY_ID: 1
      ZOO_SERVERS: server.1=zookeeper:2888:3888;zookeeper:2181
  kafka:
    restart: always
    image: wurstmeister/kafka
    depends_on:
      - zookeeper
    ports:
      - "9092:9092"
    environment:
      KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
      KAFKA_LISTENERS: INSIDE://:9093,OUTSIDE://:9092
      KAFKA_ADVERTISED_LISTENERS: INSIDE://:9093,OUTSIDE://kafka:9092
      KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: INSIDE:PLAINTEXT,OUTSIDE:PLAINTEXT
      KAFKA_INTER_BROKER_LISTENER_NAME: INSIDE
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
  mytb:
    restart: always
    image: "thingsboard/tb-postgres"
    depends_on:
      - kafka
    ports:
      - "8080:9090"
      - "1883:1883"
      - "7070:7070"
      - "5683-5688:5683-5688/udp"
    environment:
      TB_QUEUE_TYPE: kafka
      TB_KAFKA_SERVERS: kafka:9092
    volumes:
      - ~/.mytb-data:/data
      - ~/.mytb-logs:/var/log/thingsboard

如果选择【thingsboard/tb-postgres + Kafka】来安装(设备量多的情况)

需要修改TB_QUEUE_RABBIT_MQ_USERNAME、TB_QUEUE_RABBIT_MQ_PASSWORD、TB_QUEUE_RABBIT_MQ_HOST这三个配置。

version: '3.0'
services:
  mytb:
    restart: always
    image: "thingsboard/tb-postgres"
    ports:
      - "8080:9090"
      - "1883:1883"
      - "7070:7070"
      - "5683-5688:5683-5688/udp"
    environment:
      TB_QUEUE_TYPE: rabbitmq
      TB_QUEUE_RABBIT_MQ_USERNAME: YOUR_USERNAME
      TB_QUEUE_RABBIT_MQ_PASSWORD: YOUR_PASSWORD
      TB_QUEUE_RABBIT_MQ_HOST: localhost
      TB_QUEUE_RABBIT_MQ_PORT: 5672
    volumes:
      - ~/.mytb-data:/data
      - ~/.mytb-logs:/var/log/thingsboard

配置介绍

  • 8080:9090:将本地端口 8080 连接到公开的内部 HTTP 端口 9090
  • 1883:1883:将本地端口 1883 连接到公开的内部 MQTT 端口 1883
  • 7070:7070:将本地端口 7070 连接到暴露的内部边缘 RPC 端口 7070
  • 5683-5688:5683-5688/udp:将本地 UDP 端口 5683-5688 连接到公开的内部 COAP 和 LwM2M 端口
  • ~/.mytb-data:/data:将主机的目录安装~/.mytb-data到 ThingsBoard 数据库数据目录
  • ~/.mytb-logs:/var/log/thingsboard:将主机的目录安装~/.mytb-logs到 ThingsBoard 日志目录
  • mytb:容器名称
  • restart: always:系统重启时自动启动 ThingsBoard,失败时自动重启。
  • image: thingsboard/tb-postgres:镜像,也可以是thingsboard/tb-cassandra或thingsboard/tb

创建数据目录

mkdir -p ~/.mytb-data && sudo chown -R 799:799 ~/.mytb-data
mkdir -p ~/.mytb-logs && sudo chown -R 799:799 ~/.mytb-logs

5、启动

进入到thingsboard的目录下,下面有一个docker-compose.yml文件,然后选择上面合适的配置拷贝进行,然后保存,我选择的是【thingsboard/tb-postgres + In Memory】方式。

然后在当前文件目录下执行:

docker compose up -d

6、查看日志

# 查看启动后的容器名称
docker ps
# 查看容器启动的日志
docker-compose logs -f 指定容器名称

3、k8s安装

需要服务器,更新中...

以上是关于header.setContentDispositionFormData("attachment;filename*=UTF-8''", fileName);无法设的主要内容,如果未能解决你的问题,请参考以下文章