Skip to content

Commit

Permalink
Mass-replace youtube/vitess -> vitessio/vitess.
Browse files Browse the repository at this point in the history
Signed-off-by: Alain Jobart <[email protected]>
  • Loading branch information
alainjobart committed Mar 5, 2018
1 parent 70eceda commit 0ef9fdc
Show file tree
Hide file tree
Showing 56 changed files with 155 additions and 155 deletions.
2 changes: 1 addition & 1 deletion CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ the one above, the
For all contributors, we recommend the standard [GitHub flow](https://guides.github.com/introduction/flow/)
based on [forking and pull requests](https://guides.github.com/activities/forking/).

For significant changes, please [create an issue](https://github.com/youtube/vitess/issues)
For significant changes, please [create an issue](https://github.com/vitessio/vitess/issues)
to let everyone know what you're planning to work on, and to track progress and design decisions.

## Guidance for Novice Vitess Developers
Expand Down
10 changes: 5 additions & 5 deletions GOVERNANCE.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ Users who continue to engage with the project and its community will often becom

## Contributors

Contributors will be added to the [Collaborators list](https://github.com/youtube/vitess/settings/collaboration).
Contributors will be added to the [Collaborators list](https://github.com/vitessio/vitess/settings/collaboration).

Contributors are community members who contribute in concrete ways to the project. Anyone can become a contributor. There is no expectation of commitment to the project, no specific skill requirements and no selection process.

Expand All @@ -42,7 +42,7 @@ Contributors engage with the project through the issue tracker, mailing list, th
As contributors gain experience and familiarity with the project, their profile within, and commitment to, the community will increase. At some stage, they may find themselves being nominated for committership.

## Committers
Committers will be added to the [committers list](https://github.com/orgs/youtube/teams/vitess-committers) and the [pullapprove list](https://github.com/youtube/vitess/blob/master/.pullapprove.yml).
Committers will be added to the [committers list](https://github.com/orgs/youtube/teams/vitess-committers) and the [pullapprove list](https://github.com/vitessio/vitess/blob/master/.pullapprove.yml).

Committers are community members who have shown that they are committed to the continued development of the project through ongoing engagement with the community. Committership allows contributors to more easily carry on with their project related activities by giving them direct access to the project’s resources. That is, they can make changes directly to project outputs, without having to submit changes via patches.

Expand All @@ -60,7 +60,7 @@ New committers can be nominated by any existing committer. Once they have been n

Nominees may decline their appointment as a committer. However, this is unusual, as the project does not expect any specific time or resource commitment from its community members. The intention behind the role of committer is to allow people to contribute to the project more easily, not to tie them in to the project in any formal way.

It is important to recognise that commitership is a privilege, not a right. That privilege must be earned and once earned it can be removed by the PMC for conduct inconsistent with the [Guiding Principles](https://github.com/youtube/vitess/blob/master/GUIDING_PRINCIPLES.md) or if they drop below a level of commitment and engagement required to be a Committer, as determined by the PMC. The PMC also reserves the right to remove a person for any other reason inconsistent with the goals of Vitess.
It is important to recognise that commitership is a privilege, not a right. That privilege must be earned and once earned it can be removed by the PMC for conduct inconsistent with the [Guiding Principles](https://github.com/vitessio/vitess/blob/master/GUIDING_PRINCIPLES.md) or if they drop below a level of commitment and engagement required to be a Committer, as determined by the PMC. The PMC also reserves the right to remove a person for any other reason inconsistent with the goals of Vitess.

A committer who shows an above-average level of contribution to the project, particularly with respect to its strategic direction and long-term health, may be nominated to become a member of the PMC. This role is described below.

Expand All @@ -86,7 +86,7 @@ Membership of the PMC is by invitation from the existing PMC members. A nominati

The number of PMC members should be limited to 7. This number is chosen to ensure that sufficient points of view are represented, while preserving the efficiency of the decision making process.

The PMC is responsible for maintaining the [Guiding Principles](https://github.com/youtube/vitess/blob/master/GUIDING_PRINCIPLES.md) and the code of conduct. It is also responsible for ensuring that those rules and principles are followed.
The PMC is responsible for maintaining the [Guiding Principles](https://github.com/vitessio/vitess/blob/master/GUIDING_PRINCIPLES.md) and the code of conduct. It is also responsible for ensuring that those rules and principles are followed.

## PMC Chair

Expand All @@ -109,7 +109,7 @@ The Slack channel list is the most appropriate place for a contributor to ask fo

Decisions about the future of the project are made by the PMC. New proposals and ideas can be brought to the PMC’s attention through the Slack channel or by filing an issue. If necessary, the PMC will seek input from others to come to the final decision.

The PMC’s decision is itself governed by the project’s [Guiding Principles](https://github.com/youtube/vitess/blob/master/GUIDING_PRINCIPLES.md), which shall be used to reach consensus. If a consensus cannot be reached, a simple majority voting process will be used to reach resolution. In case of a tie, the PMC chair has the casting vote.
The PMC’s decision is itself governed by the project’s [Guiding Principles](https://github.com/vitessio/vitess/blob/master/GUIDING_PRINCIPLES.md), which shall be used to reach consensus. If a consensus cannot be reached, a simple majority voting process will be used to reach resolution. In case of a tie, the PMC chair has the casting vote.

# Credits
The contents of this document are based on http://oss-watch.ac.uk/resources/meritocraticgovernancemodel by Ross Gardler and Gabriel Hanganu.
2 changes: 1 addition & 1 deletion GUIDING_PRINCIPLES.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,4 @@ Vitess is driven by high technical standards, and these must be maintained. It i
* Diversity
* Inclusiveness
* Openness
* Adherence to the [Code of Conduct](https://github.com/youtube/vitess/blob/master/CODE_OF_CONDUCT.md)
* Adherence to the [Code of Conduct](https://github.com/vitessio/vitess/blob/master/CODE_OF_CONDUCT.md)
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/io.vitess/vitess-jdbc/badge.svg)](https://maven-badges.herokuapp.com/maven-central/io.vitess/vitess-jdbc)
[![Build Status](https://travis-ci.org/youtube/vitess.svg?branch=master)](https://travis-ci.org/youtube/vitess/builds)
[![Build Status](https://travis-ci.org/vitessio/vitess.svg?branch=master)](https://travis-ci.org/vitessio/vitess/builds)
[![codebeat badge](https://codebeat.co/badges/51c9a056-1103-4522-9a9c-dc623821ea87)](https://codebeat.co/projects/github-com-youtube-vitess)
[![Go Report Card](https://goreportcard.com/badge/vitess.io/vitess)](https://goreportcard.com/report/vitess.io/vitess)

Expand Down
2 changes: 1 addition & 1 deletion doc/AdvancedFeaturesIndex.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,4 @@ Examples for undocumented features:
* hot row protection in vttablet
* vtgate buffer for lossless failovers
* vttablet consolidator (avoids duplicated read queries to MySQL, turned on by default)
* [vtexplain](https://github.com/youtube/vitess/blob/master/doc/VtExplain.md)
* [vtexplain](https://github.com/vitessio/vitess/blob/master/doc/VtExplain.md)
2 changes: 1 addition & 1 deletion doc/BackupAndRestore.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ Vitess. Vitess uses backups for two purposes:

Vitess stores data backups on a Backup Storage service, which is
a
[pluggable interface](https://github.com/youtube/vitess/blob/master/go/vt/mysqlctl/backupstorage/interface.go).
[pluggable interface](https://github.com/vitessio/vitess/blob/master/go/vt/mysqlctl/backupstorage/interface.go).

Currently, we have plugins for:

Expand Down
2 changes: 1 addition & 1 deletion doc/CodeReviews.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ They'll receive an email.
During discussions, you can also refer to somebody using the *@username* syntax and they'll receive an email as well.
If you want to receive notifications even when you aren't mentioned, you can go to the [repository page](https://github.com/youtube/vitess) and click *Watch*.
If you want to receive notifications even when you aren't mentioned, you can go to the [repository page](https://github.com/vitessio/vitess) and click *Watch*.
## Approving a Pull Request
Expand Down
10 changes: 5 additions & 5 deletions doc/DockerBuild.md
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
By default, the [Kubernetes configs](https://github.com/youtube/vitess/tree/master/examples/kubernetes)
By default, the [Kubernetes configs](https://github.com/vitessio/vitess/tree/master/examples/kubernetes)
point to the `vitess/lite` image on [Docker Hub](https://hub.docker.com/u/vitess/).

We created the `lite` image as a stripped down version of our main image `base` such that Kubernetes pods can start faster.
The `lite` image does not change very often and is updated manually by the Vitess team with every release.
In contrast, the `base` image is updated automatically after every push to the GitHub master branch.
For more information on the different images we provide, please read the [`docker/README.md` file](https://github.com/youtube/vitess/tree/master/docker).
For more information on the different images we provide, please read the [`docker/README.md` file](https://github.com/vitessio/vitess/tree/master/docker).

If your goal is run the latest Vitess code, the simplest solution is to use the bigger `base` image instead of `lite`.

Expand All @@ -23,9 +23,9 @@ Then you can run our build script for the `lite` image which extracts the Vitess
1. Go to your `src/vitess.io/vitess` directory.

1. Usually, you won't need to [build your own bootstrap image]
(https://github.com/youtube/vitess/blob/master/docker/bootstrap/README.md)
unless you edit [bootstrap.sh](https://github.com/youtube/vitess/blob/master/bootstrap.sh)
or [vendor.json](https://github.com/youtube/vitess/blob/master/vendor/vendor.json),
(https://github.com/vitessio/vitess/blob/master/docker/bootstrap/README.md)
unless you edit [bootstrap.sh](https://github.com/vitessio/vitess/blob/master/bootstrap.sh)
or [vendor.json](https://github.com/vitessio/vitess/blob/master/vendor/vendor.json),
for example to add new dependencies. If you do need it then build the
bootstrap image, otherwise pull the image using one of the following
commands depending on the MySQL flavor you want:
Expand Down
8 changes: 4 additions & 4 deletions doc/GettingStarted.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,9 +45,9 @@ $ docker inspect 32f187ef9351 | grep IPAddress

You can also build Vitess Docker images yourself to include your
own patches or configuration data. The
[Dockerfile](https://github.com/youtube/vitess/blob/master/Dockerfile)
[Dockerfile](https://github.com/vitessio/vitess/blob/master/Dockerfile)
in the root of the Vitess tree builds the `vitess/base` image.
The [docker](https://github.com/youtube/vitess/tree/master/docker)
The [docker](https://github.com/vitessio/vitess/tree/master/docker)
subdirectory contains scripts for building other images, such as `vitess/lite`.

Our `Makefile` also contains rules to build the images. For example:
Expand Down Expand Up @@ -236,7 +236,7 @@ In addition, Vitess requires the software and libraries listed below.
``` sh
cd $WORKSPACE
git clone https://github.com/youtube/vitess.git \
git clone https://github.com/vitessio/vitess.git \
src/vitess.io/vitess
cd src/vitess.io/vitess
```
Expand Down Expand Up @@ -351,7 +351,7 @@ pkill -f '(vtdataroot|VTDATAROOT)' # kill Vitess processes
This error often means your disk is too slow. If you don't have access
to an SSD, you can try [testing against a
ramdisk](https://github.com/youtube/vitess/blob/master/doc/TestingOnARamDisk.md).
ramdisk](https://github.com/vitessio/vitess/blob/master/doc/TestingOnARamDisk.md).

##### Connection refused to tablet, MySQL socket not found, etc.

Expand Down
6 changes: 3 additions & 3 deletions doc/GettingStartedKubernetes.md
Original file line number Diff line number Diff line change
Expand Up @@ -193,7 +193,7 @@ $ export KUBECTL=/example/path/to/google-cloud-sdk/bin/kubectl

Direct support for other cloud blob stores like Amazon S3 can be added by
implementing the Vitess [BackupStorage plugin interface]
(https://github.com/youtube/vitess/blob/master/go/vt/mysqlctl/backupstorage/interface.go).
(https://github.com/vitessio/vitess/blob/master/go/vt/mysqlctl/backupstorage/interface.go).
Let us know on the [discussion forum](https://groups.google.com/forum/#!forum/vitess)
if you have any specific plugin requests.

Expand Down Expand Up @@ -606,7 +606,7 @@ vitess/examples/kubernetes$ ./kvtctl.sh ExecuteFetchAsDba test-0000000100 "SELEC
```

The [GuestBook source code]
(https://github.com/youtube/vitess/tree/master/examples/kubernetes/guestbook)
(https://github.com/vitessio/vitess/tree/master/examples/kubernetes/guestbook)
provides more detail about how the app server interacts with Vitess.

## Try Vitess resharding
Expand Down Expand Up @@ -697,7 +697,7 @@ x509: failed to load system roots and no roots provided
It usually means that your Kubernetes nodes are running a host OS
that puts root certificates in a different place than our configuration
expects by default (for example, Fedora). See the comments in the
[etcd controller template](https://github.com/youtube/vitess/blob/master/examples/kubernetes/etcd-controller-template.yaml)
[etcd controller template](https://github.com/vitessio/vitess/blob/master/examples/kubernetes/etcd-controller-template.yaml)
for examples of how to set the right location for your host OS.
You'll also need to adjust the same certificate path settings in the
`vtctld` and `vttablet` templates.
Expand Down
14 changes: 7 additions & 7 deletions doc/GitHubWorkflow.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ Our GitHub workflow is a so called triangular workflow:

*Image Source:* https://github.com/blog/2042-git-2-5-including-multiple-worktrees-and-triangular-workflows

The Vitess code is hosted on GitHub (https://github.com/youtube/vitess).
The Vitess code is hosted on GitHub (https://github.com/vitessio/vitess).
This repository is called *upstream*.
You develop and commit your changes in a clone of our upstream repository (shown as *local* in the image above).
Then you push your changes to your forked repository (*origin*) and send us a pull request.
Expand All @@ -28,12 +28,12 @@ origin [email protected]:<yourname>/vitess.git (push)
To help you keep your fork in sync with the main repo, add an `upstream` remote:

```
$ git remote add upstream [email protected]:youtube/vitess.git
$ git remote add upstream [email protected]:vitessio/vitess.git
$ git remote -v
origin [email protected]:<yourname>/vitess.git (fetch)
origin [email protected]:<yourname>/vitess.git (push)
upstream [email protected]:youtube/vitess.git (fetch)
upstream [email protected]:youtube/vitess.git (push)
upstream [email protected]:vitessio/vitess.git (fetch)
upstream [email protected]:vitessio/vitess.git (push)
```

Now to sync your local `master` branch, do this:
Expand All @@ -47,7 +47,7 @@ Note: In the example output above we prefixed the prompt with `(master)` to
stress the fact that the command must be run from the branch `master`.

You can omit the `upstream master` from the `git pull` command when you let your
`master` branch always track the main `youtube/vitess` repository. To achieve
`master` branch always track the main `vitessio/vitess` repository. To achieve
this, run this command once:

```
Expand Down Expand Up @@ -109,10 +109,10 @@ After this change, you can run `git push` without arguments:
(new-feature) $ git push
```

Then go to the [repository page](https://github.com/youtube/vitess) and it
Then go to the [repository page](https://github.com/vitessio/vitess) and it
should prompt you to create a Pull Request from a branch you recently pushed.
You can also [choose a branch manually]
(https://github.com/youtube/vitess/compare).
(https://github.com/vitessio/vitess/compare).

## Addressing Changes

Expand Down
10 changes: 5 additions & 5 deletions doc/LifeOfAQuery.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,21 +11,21 @@ Life of A Query

A query means a request for information from database and it involves four components in the case of Vitess, including the client application, VtGate, VtTablet and MySQL instance. This doc explains the interaction which happens between and within components.

![](https://raw.githubusercontent.com/youtube/vitess/master/doc/life_of_a_query.png)
![](https://raw.githubusercontent.com/vitessio/vitess/master/doc/life_of_a_query.png)

At a very high level, as the graph shows, first the client sends a query to VtGate. VtGate then resolves the query and routes it to the right VtTablets. For each VtTablet that receives the query, it does necessary validations and passes the query to the underlying MySQL instance. After gathering results from MySQL, VtTablet sends the response back to VtGate. Once VtGate receives responses from all VtTablets, it sends the combined result to the client. In the presence of VtTablet errors, VtGate will retry the query if errors are recoverable and it only fails the query if either errors are unrecoverable or the maximum number of retries has been reached.

## From Client to VtGate

A client application first sends an rpc with an embedded sql query to VtGate. VtGate's rpc server unmarshals this rpc request, calls the appropriate VtGate method and return its result back to client.

![](https://raw.githubusercontent.com/youtube/vitess/master/doc/life_of_a_query_client_to_vtgate.png)
![](https://raw.githubusercontent.com/vitessio/vitess/master/doc/life_of_a_query_client_to_vtgate.png)

VtGate keeps an in-memory table that stores all available rpc methods for each service, e.g. VtGate uses "VTGate" as its service name and most of its methods defined in [go/vt/vtgate/vtgate.go](../go/vt/vtgate/vtgate.go) are used to serve rpc request.

## From VtGate to VtTablet

![](https://raw.githubusercontent.com/youtube/vitess/master/doc/life_of_a_query_vtgate_to_vttablet.png)
![](https://raw.githubusercontent.com/vitessio/vitess/master/doc/life_of_a_query_vtgate_to_vttablet.png)

After receiving an rpc call from the client and one of its Execute* method being invoked, VtGate needs to figure out which shards should receive the query and send it to each of them. In addition, VtGate talks to the topo server to get necessary information to create a VtTablet connection for each shard. At this point, VtGate is able to send the query to the right VtTablets in parallel. VtGate also does retry if timeout happens or some VtTablets return recoverable errors.

Expand All @@ -35,13 +35,13 @@ A ShardConn object represents a load balanced connection to a group of VtTablets

## From VtTablet to MySQL

![](https://raw.githubusercontent.com/youtube/vitess/master/doc/life_of_a_query_vttablet_to_mysql.png)
![](https://raw.githubusercontent.com/vitessio/vitess/master/doc/life_of_a_query_vttablet_to_mysql.png)

Once VtTablet received an rpc call from VtGate, it does a few checks before passing the query to MySQL. First, it validates the current VtTablet state including the session id, then generates a query plan and applies predefined query rules and does ACL checks. It also checks whether the query hits the row cache and returns the result immediately if so. In addition, VtTablet consolidates duplicate queries from executing simultaneously and shares results between them. At this point, VtTablet has no way but pass the query down to MySQL layer and wait for the result.

## Putting it all together

![](https://raw.githubusercontent.com/youtube/vitess/master/doc/life_of_a_query_all.png)
![](https://raw.githubusercontent.com/vitessio/vitess/master/doc/life_of_a_query_all.png)

## TopoServer

Expand Down
Loading

0 comments on commit 0ef9fdc

Please sign in to comment.