add(i2c): i2c python

This commit is contained in:
GengY 2024-03-05 16:10:20 +08:00
parent 24275e1580
commit 8b8b7cd492
6 changed files with 144 additions and 3 deletions

View File

@ -1,4 +1,4 @@
# mkdir -pv /data/volumes/alist/{data,localFS} # mkdir -pv /data1/volumes/alist/{data,localFS}
# pull:: docker compose --env-file ./alist/env.yml -f ./alist/compose.yml pull # pull:: docker compose --env-file ./alist/env.yml -f ./alist/compose.yml pull
# run:: docker compose -p alist --env-file ./alist/env.yml -f ./alist/compose.yml up -d # run:: docker compose -p alist --env-file ./alist/env.yml -f ./alist/compose.yml up -d
## 随机生成一个密码 ## 随机生成一个密码

18
alist/readme.md Normal file
View File

@ -0,0 +1,18 @@
## 部署时需要注意的
1. 本地部署
1.1 需要空间
2. docker部署
2.1 需要制订
- 存储空间
```docker
...
volumes
- /data/localFS:/data
- /videos/videos:/videos
...
```
- 配置文件
2.2 alist配置
2.3 权限问题
3. 其他需要安装的一些扩展

23
i2c.py/readme.md Normal file
View File

@ -0,0 +1,23 @@
## i2c python3
1. 必须安装
```shell
apt install -y fonts-wqy-microhei fonts-wqy-zenhei
apt install -y i2c-tools libgpiod-dev
apt install -y python3-pip python3-pil python3-libgpiod
pip3 install adafruit-circuitpython-ssd13060 --break-system-packages
```
2. 调试
```shell
python3 ./status.py
```
3. rc-local
```shell
vim /etc/rc.local
# 在 exit 0 之前添加
python3 /home/yong/i2c.py/status.py &
```

82
i2c.py/status.py Normal file
View File

@ -0,0 +1,82 @@
# This example is for use on (Linux) computers that are using CPython with
# Adafruit Blinka to support CircuitPython libraries. CircuitPython does
# not support PIL/pillow (python imaging library)!
import time
import subprocess
from board import SCL, SDA
import busio
from PIL import Image, ImageDraw, ImageFont
import adafruit_ssd1306
# Create the I2C interface.
i2c = busio.I2C(SCL, SDA)
# Create the SSD1306 OLED class.
# The first two parameters are the pixel width and pixel height. Change these
# to the right size for your display!
disp = adafruit_ssd1306.SSD1306_I2C(128, 64, i2c)
# Clear display.
disp.fill(0)
disp.show()
# Create blank image for drawing.
# Make sure to create image with mode '1' for 1-bit color.
width = disp.width
height = disp.height
image = Image.new("1", (width, height))
# Get drawing object to draw on image.
draw = ImageDraw.Draw(image)
# Draw a black filled box to clear the image.
draw.rectangle((0, 0, width, height), outline=0, fill=0)
# Draw some shapes.
# First define some constants to allow easy resizing of shapes.
padding = -2
top = padding
bottom = height - padding
# Move left to right keeping track of the current x position for drawing shapes.
x = 0
# Load default font.
#font = ImageFont.load_default()
# Alternatively load a TTF font. Make sure the .ttf font file is in the
# same directory as the python script!
# Some other nice fonts to try: http://www.dafont.com/bitmap.php
font = ImageFont.truetype('/usr/share/fonts/truetype/wqy/wqy-microhei.ttc', 11)
while True:
# Draw a black filled box to clear the image.
draw.rectangle((0, 0, width, height), outline=0, fill=0)
# Shell scripts for system monitoring from here:
# https://unix.stackexchange.com/questions/119126/command-to-display-memory-usage-disk-usage-and-cpu-load
cmd = "hostname -I | cut -d' ' -f1"
IP = subprocess.check_output(cmd, shell=True).decode("utf-8")
cmd = 'cut -f 1 -d " " /proc/loadavg'
CPU = subprocess.check_output(cmd, shell=True).decode("utf-8")
cmd = "free -m | awk 'NR==2{printf \"Mem: %s/%s MB %.2f%%\", $3,$2,$3*100/$2 }'"
MemUsage = subprocess.check_output(cmd, shell=True).decode("utf-8")
cmd = 'df -h | awk \'$NF=="/data"{printf "Disk: %d/%d GB %s", $3,$2,$5}\''
Disk = subprocess.check_output(cmd, shell=True).decode("utf-8")
date_time = time.strftime("%Y-%m-%d, %H:%M:%S")
# Write four lines of text.
draw.text((x, top + 1), "IP: " + IP, font=font, fill=255)
draw.text((x, top + 13), "CPU: " + CPU, font=font, fill=255)
draw.text((x, top + 23), MemUsage, font=font, fill=255)
draw.text((x, top + 35), Disk, font=font, fill=255)
draw.text((x, top + 47), date_time, font=font, fill=255)
# Display image.
disp.image(image)
disp.show()
time.sleep(0.1)

View File

@ -2,9 +2,9 @@
IMAGE_TAG=florider89/joplin-server:2.14.2 IMAGE_TAG=florider89/joplin-server:2.14.2
# only amd64 # only amd64
#IMAGE_TAG=joplin/server:2.14.2-beta #IMAGE_TAG=joplin/server:2.14.2-beta
APP_BASE_URL=http://10.10.13.233:22300 APP_BASE_URL=http://192.168.100.184:22300
POSTGRES_USER=postgres POSTGRES_USER=postgres
POSTGRES_PASSWORD=Kevin0412PgSql POSTGRES_PASSWORD=Kevin0412PgSql
POSTGRES_DATABASE=joplin-db POSTGRES_DATABASE=joplin-db
POSTGRES_PORT=5432 POSTGRES_PORT=5432
POSTGRES_HOST=10.10.13.233 POSTGRES_HOST=192.168.100.184

18
nextcloud/readme.md Normal file
View File

@ -0,0 +1,18 @@
# 一点小测评
```toml
date = 2024-03-11T23:24:29 +8:00
```
## nextcloud VS owncloud-ocis
### ownCloud Infinite Scale (oCIS)
1. ownCloud Infinite Scale (oCIS)是新一代的ownCloud前后端都重构了体积更小界面更加现代化动画也挺流畅支持了复制和剪切可以在线查看和编辑Markdown支持电脑和移动客户端同步。
2. 它不依赖于PHP或数据库这样的外部软件包消除了使用它们所带来的所有麻烦。凭借其现代架构Infinite Scale 为云基础架构部署提供所有部署模型,并优化缩放设置,给投入带来最佳产出。
3. 目前新的Web界面还没有支持中文
4. 支持 docker 部署, 详细文档 [owncloud/ocis](https://hub.docker.com/r/owncloud/ocis)
### nextcloud
1. NextCloud是用于基于Linux系统的开源云存储平台。
2. 支持PostgresqlSqliteMariadBMySQL和Oracle数据库。
3. NextCloud于2016年推出ownCloud于2010年1月发布但第一个Beta版本于2010年3月启动。并于2012年发布了OwnCloud。NextCloud于2016年推出当时Frank Karlitschek分叉了OwnCloud创建NextCloud。
4. NextCloud提供了防止蛮力攻击流量限制速率限制密码管理内容安全策略和许多其他安全选项的保护。