2023年1月7日 星期六

俄國網站

 https://dzen.ru/?auth=login

https://help.mail.ru/atom


https://ok.ru/feedhttps://cloud.mail.ru/?utm_source=portal&utm_medium=mailbox&utm_campaign=cloud.mail.ru&mt_click_id=mt-z4dsz4-1673143139-1024884403


https://cloud.mail.ru/promo/newyear/?utm_source=portal&utm_medium=logo_main&utm_campaign=new_year_dance


https://dzen.ru/?auth=login


https://mail.ru/


2020年6月7日 星期日

Rclone 750G自动换号– AutoRclone使用教程

博主经常看到有人在论坛或者QQ/Telegram群组发问

怎么快速拷贝1000T资源到我的Google Drive

必须是Rclone/AutoRclone啊!一直不想写关于AutoRclone的(中文)教程,因为其一直处于测试阶段,如果后面代码有大的更新那么前面的教程对于后面的人来说就是一个误导。但是现在应该不会有大的更新了,而且这么长时间的测试发现如果没有一个详细的教程的话,会让很多不会程序的小白错过这么好的工具 :)

AutoRclone是一个用Python写的小程序集合,其

  • 学习了folderclone利用service accounts来替代普通Google账号进行拷贝/上传;
  • 通过rclone rc来做到对Rclone任务的监、控;
  • 还可以用Google Groups的形式对成百上千的service accounts进行管理

从而方便快速地

  • 从本地到 Team Drive,
  • 从公共分享目录到 Team Drive,
  • 再或者从 Team Drive 到 Team Drive。

其食用方法极其简单!

步骤 1 下载代码

首先不管你是哪个操作系统,需要安装Python。对于Linux和Windows分别用以下方式安装相关脚本
Linux: 安装screen,git和最新的Rclone。如果是Debian/Ubuntu,直接输入以下命令

sudo apt-get install screen git && curl https://rclone.org/install.sh | sudo bash

然后从Github下载代码并安装相关Python依赖包

sudo git clone https://github.com/xyou365/AutoRclone && cd AutoRclone && sudo pip3 install -r requirements.txt

Windows: 安装最新的Rclone,直接从Github下载AutoRclone后在Windows的cmd或PowerShell中切换到AutoRclone的目录,输入以下命令安装相关Python依赖包

pip3 install -r requirements.txt

以下步骤如果输入python3没有反应,请输入python或者py3

以下所有步骤由于需要用到谷歌服务,请确保cmd或者vps能够富强

步骤 2 生成service accounts

首先开启Drive API并将credentials.json保存到你的AutoRclone目录下面

开启Drive API

Drive API

然后分三种情况

如果你之前没创建过项目, 直接运行

python3 gen_sa_accounts.py --quick-setup 5
  • 创建6个项目(项目0到项目5)
  • 开启相关的服务
  • 创建600个service accounts(6个项目,每个项目100个)
  • 将600个service accounts的授权文件下载到accounts文件夹下面

如果你已经有N个项目,现需要创建新的项目并在新的项目中创建service accounts,直接运行

python3 gen_sa_accounts.py --quick-setup 2 --new-only
  • 额外创建2个项目(项目N+1到项目N+2)
  • 开启相关的服务
  • 创建200个service accounts(2个项目,每个项目100个)
  • 将200个service accounts的授权文件下载到accounts文件夹下面

如果你想用已有的项目来创建service accounts(不创建新的项目),直接运行

python3 gen_sa_accounts.py --quick-setup -1

注意这会覆盖掉已有的service accounts
顺利完成后,AutoRclone文件下面的accounts文件夹下会有很多的json文件。

步骤 3 可选:将service accounts加入Google Groups

为了方便管理service accounts,也是为了让我们的Team Drive可以容纳更多的service accounts,我们这里用到了Google Groups。

Official limits to the members of Team Drive (Limit for individuals and groups directly added as members is 600).

对于G Suite管理员

  1. 按照官方步骤开启Directory API,将生成的json文件保存到credentials文件下。
  2. 控制面版里面创建一个群组,创建好你会获得一个类似域名邮箱的地址[[email protected]](/cdn-cgi/l/email-protection)
  3. 利用API将service accounts加入Google Groups

    python3 add_to_google_group.py -g [[email protected]](/cdn-cgi/l/email-protection)

如果想看参数的具体含义,直接运行python3 add_to_google_group.py -h

对于普通Google账号
直接创建一个Google Group然后手动地将service accounts对应的邮箱地址(可以在json认证文件中找到)挨个加进去。但每次只能加10个,每24小时只能加100个。

步骤 4 将service accounts或者Google Groups加入到Team Drive

- 如果你没有Team Drive,那可以找朋友帮你开一个或者去买一个,实在不嫌弃也可以留言找博主开一个
- 如果你已经在完成了步骤2中的用Google Groups来管理service accounts,那么直接将Google Groups地址[[email protected]](/cdn-cgi/l/email-protection)或者[[email protected]](/cdn-cgi/l/email-protection)glegroups.com加入你的源Team Drive(tdsrc)和目标Team Drive(tddst)
- 如果你在步骤2中没有生成并保存credentials.json那么再做一遍

将service accounts加入到源Team Drive

python3 add_to_team_drive.py -d SharedTeamDriveSrcID

将service accounts加入到目标Team Drive

python3 add_to_team_drive.py -d SharedTeamDriveDstID

步骤 5 开始拷贝/上传

准备工作都做好了,以后你只需要将项目文件夹拷贝到任何地方,进行此拷贝/上传步骤就可以啦

拷贝

python3 rclone_sa_magic.py -s SourceID -d DestinationID -dp DestinationPathName -b 1 -e 600
  • 如果想看参数的具体含义,直接运行python3 rclone_sa_magic.py -h
  • 特别地,如果想多开,请用-p参数给不同的复制任务指定不同的端口
  • 如果发现拷贝内容明显少于源Team Drive里面的内容,那么你可能碰到Bug了,请给上运行参数再加上--disable_list_r
  • 如果你一开始就碰到了

Failed to rc: connection failed: Post http://localhost:5572/core/stats: dial tcp :5572: connectex: No connection could be made because the target machine actively refused it.
那么可能是权限或者路径导致Rclone任务都没跑起来,请观察日志文件log_rclone.txt,并结合如下简单命令检查出原因rclone --config rclone.conf size --disable ListR src001:rclone --config rclone.conf size --disable ListR dst001:

上传

python3 rclone_sa_magic.py -sp YourLocalPath -d DestinationID -dp DestinationPathName -b 1 -e 600

拷贝截图

拷贝

不出意外应该就可以跑起来了。每个service account的总的时间消耗是校验时间+拷贝时间,如果你的拷贝任务比较大的话建议将其(按文件夹)稍微拆分,挨个或者并行完成,这样能极大减小每次切换service accounts后不必要的校验时间。另外关于拷贝速度,API调用限制了每秒不超过10次调用,每次拷贝固定数量的文件数目,所以如果你的任务中的文件比较小的话,拷贝速度可能是每秒几百MB,文件都比较大的话,拷贝速度可能是几十GB/s。

一些 Q & A

Q. 怎么检查是否拷贝完全?发现丢文件了?

A. 拷贝完请做以下检查

rclone --config rclone.conf size src001:源路径
rclone --config rclone.conf size dst001:目标路径

如果发现目标盘比源盘体积还要大,那么对目标盘进行去重;如果发现目标盘比源盘少文件了,那么再拷贝一次;如果还是少,那么就是源盘里面的有重复文件了,直接对其进行去重复。去重命令:

rclone --config rclone.conf dedupe dst001:源路径
rclone --config rclone.conf dedupe src001:目标路径

2020年6月6日 星期六

Google API客戶端

https://github.com/googleapis/google-api-python-client


https://github.com/googleapis/google-api-python-client

https://github.com/googleapis/google-api-python-client/blob/master/docs/README.md
https://github.com/googleapis/google-api-python-client/blob/master/docs/README.md



Google API客戶端

PyPI版本

這是Google的基於發現的API的Python客戶端庫。要開始使用,請參閱docs文件夾

這些客戶端庫得到Google的正式支持。但是,這些庫被認為是完整的並且處於維護模式。這意味著我們將解決嚴重的錯誤和安全性問題,但不會添加任何新功能。

文獻資料

有關更多詳細說明和其他文檔,請參閱docs文件夾

其他Google API庫

對於數據存儲,雲存儲或發布/訂閱之類的Google Cloud Platform API,我們建議使用Cloud Client Libraries for Python

對於Google Ads API,我們建議使用適用於Python的Google Ads API客戶端庫

對於Google Firebase Admin API,我們建議使用Firebase Admin Python SDK

安裝

使用pip virtualenv中安裝此庫virtualenv是用於創建隔離的Python環境的工具。它解決的基本問題是依賴關係和版本之一,以及間接權限。

使用virtualenv,可以在不需要係統安裝權限且不與已安裝的系統依賴項衝突的情況下安裝該庫。

Mac / Linux

pip install virtualenv
virtualenv <your-env>
source <your-env>/bin/activate
<your-env>/bin/pip install google-api-python-client

視窗

pip install virtualenv
virtualenv <your-env>
<your-env>\Scripts\activate
<your-env>\Scripts\pip.exe install google-api-python-client

支持的Python版本

完全支持並測試了Python 3.5、3.6、3.7和3.8。該庫可能在3的更高版本上可用,但我們目前尚未針對這些版本運行測試

不推薦使用的Python版本

Python == 2.7

第三方庫和依存關係

在安裝客戶端庫時,將安裝以下庫:

為了進行開發,您還將需要以下庫:

貢獻

請參閱貢獻頁面以獲取更多信息。特別是,我們喜歡請求請求-但請確保簽署貢獻者許可協議。

適用於Python文檔的Google API客戶端庫

Google API Client Library for Python Docs

The Google API Client Library for Python is designed for Python client-application developers. It offers simple, flexible access to many Google APIs.

Features

  • Call Google APIs simply
  • Handle Auth with fewer lines of code
  • Use standard tooling for installation

Documentation

Learn how to use the Google API Python Client with these guides:

Usage Guides

Reference Documentation





Google API Client

PyPI version

This is the Python client library for Google's discovery based APIs. To get started, please see the docs folder.

These client libraries are officially supported by Google. However, the libraries are considered complete and are in maintenance mode. This means that we will address critical bugs and security issues but will not add any new features.

Documentation

See the docs folder for more detailed instructions and additional documentation.

Other Google API libraries

For Google Cloud Platform APIs such as Datastore, Cloud Storage or Pub/Sub, we recommend using Cloud Client Libraries for Python.

For Google Ads API, we recommend using Google Ads API Client Library for Python.

For Google Firebase Admin API, we recommend using Firebase Admin Python SDK.

Installation

Install this library in a virtualenv using pip. virtualenv is a tool to create isolated Python environments. The basic problem it addresses is one of dependencies and versions, and indirectly permissions.

With virtualenv, it's possible to install this library without needing system install permissions, and without clashing with the installed system dependencies.

Mac/Linux

pip install virtualenv
virtualenv <your-env>
source <your-env>/bin/activate
<your-env>/bin/pip install google-api-python-client

Windows

pip install virtualenv
virtualenv <your-env>
<your-env>\Scripts\activate
<your-env>\Scripts\pip.exe install google-api-python-client

Supported Python Versions

Python 3.5, 3.6 and 3.7, and 3.8 are fully supported and tested. This library may work on later versions of 3, but we do not currently run tests against those versions

Deprecated Python Versions

Python == 2.7

Third Party Libraries and Dependencies

The following libraries will be installed when you install the client library:

For development you will also need the following libraries:

Contributing

Please see the contributing page for more information. In particular, we love pull requests - but please make sure to sign the contributor license agreement.