Skip to content

Web engine can be distributed among multiple devices so that any specific process can run on its own device. Each tab can be rendered by renderer process which is running on the same device usually or different device connected through network.

Notifications You must be signed in to change notification settings

hyunaranda/Castanets

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 

Repository files navigation

How to build & run distributed-chrome

Install depot_tools

Clone the depot_tools repository:

$ git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git

Add depot_tools to the end of your PATH (you will probably want to put this in your ~/.bashrc or ~/.zshrc). Assuming you cloned depot_tools to /path/to/depot_tools:

$ export PATH="$PATH:/path/to/depot_tools"

Get the code

Create a chromium directory for the checkout and change to it (you can call this whatever you like and put it wherever you like, as long as the full path has no spaces):

$ mkdir path/to/distributed_chrome && cd path/to/distributed_chrome

Download the code using the command below.

$ git clone https://github.sec.samsung.net/RS7-HighPerformanceWeb/distributed_chrome.git src

If you did not specify the 'src' directory name at the end of the command, the source code would have been downloaded to the 'distributed_chrome' directory. In this case, change the directory name.

$ mv distributed_chrome src

Install additional build dependencies

$ build/install-build-deps.sh

Run the sync

We need a gclient configuration. To create a .gclient file, run:

$ build/create_gclient.sh

Once you've run install-build-deps at least once, you can now run the Chromium-specific sync, which will download additional binaries and other things you might need:

$ gclient sync --with_branch_head

If you get an SSL certificate error at Seoul R&D center, follow the directions below.

$ cd path/to/depot_tools
$ git checkout 3beabd0aa40ca39216761418587251297376e6aa
$ git apply path/to/distributed_chrome/src/build/SRnD_depot_tools.patch

If you get SSL3_GET_SERVER_CERTIFICATE error, follow the directions below.

Add below line to .bashrc file.

export NO_AUTH_BOTO_CONFIG=~/.boto

Create ~/.boto file for the following content.

[Boto]
proxy = 10.112.1.178
proxy_port = 8080
https_validate_certificates = False

Setting up the build

Chromium uses Ninja as its main build tool along with a tool called GN to generate .ninja files. You can create any number of build directories with different configurations. To create a build directory, run:

$ gn gen out/Default

You set build arguments on a build directory by typing:

$ gn args out/Default

This will bring up an editor. Type build args into that file like this:

enable_chromie=true
enable_nacl=false

Build distributed-chrome

Build Distributed Chromium (the “chrome” target) with Ninja using the command:

$ ninja -C out/Default chrome

Run distributed-chrome

Device A: Browser Process

$ ./chrome <URL>

Device B: Renderer Process

$ ./chrome --type=renderer --server-address=<IP ADDR>

About

Web engine can be distributed among multiple devices so that any specific process can run on its own device. Each tab can be rendered by renderer process which is running on the same device usually or different device connected through network.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published