mirror of
				https://gitea.invidious.io/iv-org/documentation.git
				synced 2024-08-15 00:53:34 +00:00 
			
		
		
		
	improve doc about ipv6 rotator
This commit is contained in:
		
							parent
							
								
									6f18258890
								
							
						
					
					
						commit
						0f7666daf1
					
				
					 1 changed files with 29 additions and 20 deletions
				
			
		|  | @ -6,30 +6,38 @@ This tutorial has been written by [unixfox](https://github.com/unixfox), owner o | ||||||
| 
 | 
 | ||||||
| YouTube has started to periodically block the public Invidious instances since the start of June 2023 ([iv-org/invidious/issues/3872](https://github.com/iv-org/invidious/issues/3872)) and they have become more aggressive about it since the start of August 2023 ([iv-org/invidious/issues/4045](https://github.com/iv-org/invidious/issues/4045)). | YouTube has started to periodically block the public Invidious instances since the start of June 2023 ([iv-org/invidious/issues/3872](https://github.com/iv-org/invidious/issues/3872)) and they have become more aggressive about it since the start of August 2023 ([iv-org/invidious/issues/4045](https://github.com/iv-org/invidious/issues/4045)). | ||||||
| 
 | 
 | ||||||
| Thanks to IPv6 you can easily escape this block because there are many addresses in a single /64 IPv6 range. (18,446,744,073,709,551,616 addresses to be precise) | Thanks to IPv6 you can easily escape this block because there are many IP addresses in a single /64 IPv6 range. (18,446,744,073,709,551,616 IP addresses to be precise) | ||||||
| 
 | 
 | ||||||
| This tutorial will explain how to automatically and periodically rotate your IPv6 address. Also some notes about how to have IPv6 in case your provider does not offer it. | This tutorial will explain how to automatically and periodically rotate your IPv6 address. Also some notes about how to have IPv6 in case your provider does not offer it. | ||||||
| 
 | 
 | ||||||
| ## Requirements | ## Requirements | ||||||
| #### 1) IPv6 support on your server | #### 1) IPv6 support on your server | ||||||
| ##### Testing | ##### Testing | ||||||
| You can easily find out if you have IPv6 by executing the command `curl -m 5 ipv6.icanhazip.com`.    | You can easily find out if you have IPv6 by executing the command: | ||||||
| If you do not have any errors, then congratulation, you can continue to the second requirement! | ``` | ||||||
|  | curl -m 5 ipv6.icanhazip.com | ||||||
|  | ```      | ||||||
|  | If you do not have any errors, then congratulation, you can continue to [the second requirement](#2-system-packages-requirement)! | ||||||
| 
 | 
 | ||||||
| If you do have an error (timeout or no route to host), then you will need to enable IPv6 support on your server.   | If you do have an error (timeout or no route to host), then you will need to enable IPv6 support on your server.   | ||||||
| Depending on your provider and if it does support IPv6, you may have to configure your server for IPv6. Check the documentation of your provider. | Depending on your provider and if it does support IPv6, you may have to configure your server for IPv6. Check the documentation of your provider. | ||||||
| 
 | 
 | ||||||
| ##### Other solutions if you do not have IPv6 support | ##### Other solutions if you do not have IPv6 support | ||||||
| 
 | 
 | ||||||
|  | ###### 1) Switch to another provider | ||||||
|  | 
 | ||||||
| If your provider does not support IPv6 then you can either switch to another provider that support IPv6.   | If your provider does not support IPv6 then you can either switch to another provider that support IPv6.   | ||||||
| There are many today that do support it, here is a non-exhaustive list of them (**this is not recommendation, just a list of the popular providers that support IPv6**):   | There are many today that do support it, here is a non-exhaustive list of them (**this is not recommendation, just a list of the popular providers that support IPv6**):   | ||||||
| Hetzner, BuyVM, Scaleway, OVH, DigitalOcean, Vultr, Incognet, Netcup and more. Larger list: https://www.serverhunter.com/#query=ips%3Aipv6    | Hetzner, BuyVM, Scaleway, OVH, DigitalOcean, Vultr, Incognet, Netcup and more.    | ||||||
| Nowadays, it's hard to find one that does not support IPv6. | Larger list: https://www.serverhunter.com/#query=ips%3Aipv6    | ||||||
|  | 
 | ||||||
|  | ###### 2) Use an IPv6 tunnelbroker or make one yourself | ||||||
| 
 | 
 | ||||||
| The alternative, if you do not want to switch provider, is to use an IPv6 tunnelbroker, it allows to get IPv6 connectivity using another server. | The alternative, if you do not want to switch provider, is to use an IPv6 tunnelbroker, it allows to get IPv6 connectivity using another server. | ||||||
| 
 | 
 | ||||||
| This website lists all the free and paid existing tunnelbrokers: https://tunnelbroker.services/. **We do not recommend running a public instance on a free tunnelbroker as this would put a lot of strain on their network because video streaming consumes a lot of bandwidth.**   | This website lists all the free and paid existing tunnelbrokers: https://tunnelbroker.services/. **We do not recommend running a public instance on a free tunnelbroker as this would put a lot of strain on their network because video streaming consumes a lot of bandwidth.**   | ||||||
| You can also use an external server for acting as an IPV6 tunnel. Wireguard is perfectly suited for that.   | 
 | ||||||
|  | You can also use an external server (from another provider that do support IPv6) for acting as an IPV6 tunnel for your main server. Wireguard is perfectly suited for that.   | ||||||
| All of this is out of scope of this tutorial, please consult the internet for tutorials. | All of this is out of scope of this tutorial, please consult the internet for tutorials. | ||||||
| 
 | 
 | ||||||
| #### 2) System packages requirement | #### 2) System packages requirement | ||||||
|  | @ -48,8 +56,8 @@ Please install: | ||||||
| ### If you are running Invidious outside of Docker or using something else than Docker (K8s) | ### If you are running Invidious outside of Docker or using something else than Docker (K8s) | ||||||
| You probably have nothing to do! | You probably have nothing to do! | ||||||
| 
 | 
 | ||||||
| Except checking in your config.yml if you do not have this line set: | Except checking in your config.yml if you do not have this line set, if so remove it: | ||||||
| ``` | ```yaml | ||||||
| force_resolve: ipv4 | force_resolve: ipv4 | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -60,7 +68,6 @@ Note: Make sure you are running a recent version of Docker if you are running in | ||||||
| 
 | 
 | ||||||
| 1. Follow the steps 1 to 3 on the official documentation for Docker: https://docs.docker.com/config/daemon/ipv6/ | 1. Follow the steps 1 to 3 on the official documentation for Docker: https://docs.docker.com/config/daemon/ipv6/ | ||||||
| 2. In your docker-compose file of invidious. Add these lines at the end of your docker-compose | 2. In your docker-compose file of invidious. Add these lines at the end of your docker-compose | ||||||
|     |  | ||||||
|    ```yaml |    ```yaml | ||||||
|    networks: |    networks: | ||||||
|      default: |      default: | ||||||
|  | @ -71,15 +78,20 @@ Note: Make sure you are running a recent version of Docker if you are running in | ||||||
|              gateway: fd01:db8:a::1 |              gateway: fd01:db8:a::1 | ||||||
| 
 | 
 | ||||||
|    ``` |    ``` | ||||||
| 
 |  | ||||||
| 3. Bring down your docker composition and bring it back up for recreating the network: | 3. Bring down your docker composition and bring it back up for recreating the network: | ||||||
|     |  | ||||||
|    ``` |    ``` | ||||||
|    docker compose down |    docker compose down | ||||||
|    docker compose up -d |    docker compose up -d | ||||||
|    ``` |    ``` | ||||||
|   | 4. To check if everything went well then do: | ||||||
| To check if everything went well then do `docker compose exec invidious ping -c 1 ipv6.icanhazip.com` and if you do not get any error then you can jump to the next step. |    ``` | ||||||
|  |    docker compose exec invidious ping -c 1 ipv6.icanhazip.com | ||||||
|  |    ``` | ||||||
|  |    If you do not get any error then you can jump to the next step. | ||||||
|  | 5. **Finally**, check if you do not have this line configured in your `config.yml`, if so remove it: | ||||||
|  |    ```yaml | ||||||
|  |    force_resolve: ipv4 | ||||||
|  |    ``` | ||||||
| 
 | 
 | ||||||
| ## Configure the IPv6 rotator (made by Invidious team) | ## Configure the IPv6 rotator (made by Invidious team) | ||||||
| This tool was developed by the Invidious team, and it's the official tool for rotating your IPv6 address on Invidious: https://github.com/iv-org/smart-ipv6-rotator.   | This tool was developed by the Invidious team, and it's the official tool for rotating your IPv6 address on Invidious: https://github.com/iv-org/smart-ipv6-rotator.   | ||||||
|  | @ -87,7 +99,6 @@ It may be used on other projects that depend on YouTube and/or Google (example: | ||||||
| 
 | 
 | ||||||
| 1. Make sure you have installed all the python libraries from [the "requirements"](#requirements). | 1. Make sure you have installed all the python libraries from [the "requirements"](#requirements). | ||||||
| 2. Clone the repository somewhere that you like (not inside the invidious directory): | 2. Clone the repository somewhere that you like (not inside the invidious directory): | ||||||
|     |  | ||||||
|    ``` |    ``` | ||||||
|    git clone https://github.com/iv-org/smart-ipv6-rotator.git |    git clone https://github.com/iv-org/smart-ipv6-rotator.git | ||||||
|    ``` |    ``` | ||||||
|  | @ -96,20 +107,18 @@ It may be used on other projects that depend on YouTube and/or Google (example: | ||||||
|    Enter the main IPv6 address, select IPv6 and change the prefix length only if it's not a /64.   |    Enter the main IPv6 address, select IPv6 and change the prefix length only if it's not a /64.   | ||||||
|    Use the command `ip a` to get the detail of your IPv6 network configuration. |    Use the command `ip a` to get the detail of your IPv6 network configuration. | ||||||
| 4. Run the script once like this (don't use sudo if you are already root): | 4. Run the script once like this (don't use sudo if you are already root): | ||||||
|     |  | ||||||
|    ``` |    ``` | ||||||
|    sudo python smart-ipv6-rotator.py run --ipv6range=YOURIPV6SUBNET/64 |    sudo python smart-ipv6-rotator.py run --ipv6range=YOURIPV6SUBNET/64 | ||||||
|    ``` |    ``` | ||||||
| 5. If everything went well, then configure a cron to periodically rotate your IPv6 range. Twice a day (noon and midnight) is enough for YouTube servers. Also at the reboot of the server! | 5. If everything went well, then configure a cron to periodically rotate your IPv6 range. Twice a day (noon and midnight) is enough for YouTube servers. Also at the reboot of the server! | ||||||
|    Example crontab (`crontab -e -u root`): |    Example crontab (`crontab -e -u root`): | ||||||
|     |  | ||||||
|    ``` |    ``` | ||||||
|    @reboot sleep 30s && python smart-ipv6-rotator.py run --ipv6range=YOURIPV6SUBNET/64 |    @reboot sleep 30s && python /path/to/the/script/smart-ipv6-rotator.py run --ipv6range=YOURIPV6SUBNET/64 | ||||||
|    0 */12 * * * python smart-ipv6-rotator.py run --ipv6range=YOURIPV6SUBNET/64 |    0 */12 * * * python /path/to/the/script/smart-ipv6-rotator.py run --ipv6range=YOURIPV6SUBNET/64 | ||||||
|    ```   |    ```   | ||||||
|     |  | ||||||
|    The `sleep` command is used in case your network takes too much time time to be ready. |    The `sleep` command is used in case your network takes too much time time to be ready. | ||||||
|  6. That's it! | 
 | ||||||
|  | That's it! | ||||||
| 
 | 
 | ||||||
| If the script does not work for you, it could be that: | If the script does not work for you, it could be that: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue