Software Engineering / Site Reliability Engineering Internship

Job Title: Software Engineering / Site Reliability Engineering Internship
Contract Type: Internship
Location: Zurich, London, Munich, Paris, Dublin, Warsaw, Stockholm, Aarhus, Tel Aviv, Haifa
Job Published: November 09, 2017 10:23

Job Description

Software Engineering:

Google's Software Engineers develop the next-generation technologies that change how billions of users connect, explore, and interact with information and one another. Our products need to handle information at massive scale, and extend well beyond web search. We're looking for engineers who bring fresh ideas from all areas, including information retrieval, distributed computing, large-scale system design, networking and data storage, security, artificial intelligence, natural language processing, UI design and mobile; the list goes on and is growing every day. As a Software Engineer, you will work on a specific project critical to Google's needs, with opportunities to switch teams and projects as you, and our fast-paced business, grow and evolve. We need our engineers to be versatile, to display leadership qualities and to be enthusiastic in tackling new problems across the full-stack as we continue to push technology forward. As a key member of a versatile team, you design, test, deploy and maintain software solutions.

Site Reliability Engineering (SRE):

Google's Site Reliability Engineers apply software engineering skills in their mission to progress, protect, and provide for the software and systems behind all of Google's public services - Search, Ads, Gmail, Android, YouTube and App Engine, to name just a few - with an ever-watchful eye on their availability, latency, performance and capacity. At Google, we have developed many unique systems ranging from planet-spanning databases, to near real-time scalable data warehousing, to fault-tolerant datastream joining. In SRE, we flip between the fine-grained detail of disk driver I/O scheduling to the big picture of continental-level service capacity, across a range of systems and a user population measured in billions. As a Site Reliability Engineering Intern, you will work on software development projects to keep important, revenue-critical systems up and running. Our engineers create, fix, extend and scale the code to keep it working and to harden it against all the vagaries of the internet. We drive reliability and performance across massive scale by mastering the full depth of the stack. We literally do learn something new every day - usually surprising things - that have the potential to transform the lives of billions of our users around the world.

Required Skills

Minimum qualifications:

  • Currently enrolled in a full-time Bachelor's or Master's in Computer Science or a related technical field. Returning to education on a full-time basis upon completing the internship.
  • Completed projects (inside or outside of school) or classes focused on Data Structures and Algorithms, resulting in experience with selecting and implementing algorithms and using appropriate data structures to efficiently solve a problem; experience in interpreting algorithms and contributing ideas to their development.
  • Experience writing code fixes and tools to solve problems (e.g. remove duplicate elements from a list) in one or more of the following languages: C++, Java or Python.
  • Experience with linear coding and use language features when necessary (e.g. data structures, branching, function-calls and conditionals).

Preferred qualifications:

  • Technology internship experience or work experience (i.e. research assistant, teaching assistant, personal projects, etc) programming in two or more of the following languages: C++, Java or Python.
  • Interest in systems software or algorithms and in analyzing and troubleshooting large-scale distributed systems.
  • Demonstrated knowledge of UNIX/Linux or Windows environments, as well as APIs. Demonstrated familiarity with TCP/IP and network programming.
  • Ability to develop thorough testing solutions across testing layers (e.g. unit, functional, integration, stress testing) for your code, using at least one of the following languages: C++, Java or Python.
  • Ability to manipulate code to improve system availability and latency and to optimize code for stability, functionality and scalability for a segment of Google's infrastructure, service area, or within a technology domain (e.g. crawling, search, troubleshooting).
  • Ability to isolate problems to a database subsystem.


Please apply via Durations and start dates vary according to project and location. Applications will be reviewed on a rolling basis and our recruitment team will determine where you fit best based on your resume.

Get similar jobs like these by email

By submitting your details you agree to our T&C's