This position is ideal for an experienced software engineer who is passionate about solving challenging business problems and building applications that have high availability & resiliency. The candidate will be extensively involved in hands-on performance & chaos engineering activities including POCs, design, documentation, code instrumentation, profiling and monitoring application, middleware & platforms components. You will be an integral part of the Open VisaNet performance engineering team.
Essential Functions
Responsible for developing performance plans and models for applications and infrastructure in a highly scalable, low-latency, high-availability, and high-throughput payment processing system.
Comprehend and take ownership of component-level performance engineering tasks, including code and data flow reviews.
Create and participate in performance and resiliency testing and fine-tuning of distributed components.
Collaborate with Development, Test Engineering, Support, and Product & Project Management teams to review and document requirements & timelines
Assess, create, and execute load-testing tools to simulate workload limits for Visas most critical payment applications.
Engage in performance engineering with a shift-left approach on microservices and establish benchmarks. Proficiency in Go Benchmarks and Go Profiling is advantageous.
Design and carry out chaos-resiliency evaluation experiments on microservices to identify potential resiliency weaknesses and failure points.
Perform root cause analysis for identified issues.
Analyze metrics and trends to find opportunities for enhancing application performance.
Explore methods to resolve issues and present corrective actions, conduct sessions with developers and architects to discuss recommended improvements or techniques.
Oversee the system performance lifecycle and identify key metrics for performance enhancements.
Generate regular performance engineering reports for review by architects, developers, and project managers.
Deliver technical presentations to guide teams on improving system and application performance.
Innovate solutions to enhance the effectiveness of performance engineering.
Contribute to performance tuning, scalability, reliability, and high availability of fault-tolerant distributed components.
Ensure proper documentation and internal publication of design trade-offs, code best practices, and lessons learned.
Support in triaging and troubleshooting highly distributed services in production environments.
Design and develop performance engineering aids like profiles, traces, or any observability frameworks.
Establish and promote performance best practices and influence non-functional requirements at early stages.
Work closely with application development teams to provide technical direction for improving application performance.
Mandatory Skillset
In-depth understanding of application performance KPIs, including their trade-offs and patterns
Capability in performance modeling using performance test data tailored to specific non-functional requirements of an application
Solid grasp of microservices architecture, CGROUP, and namespaces within Linux
Comprehensive knowledge of Linux memory management systems
Expert understanding of the IO subsystem, including its layers, various types of IO operations, caching mechanisms, file systems, and RAID configuration
Proficient in the compute subsystem with detailed knowledge of process, thread, and goroutines or LWT scheduling
Familiarity with process states, context switching, and system calls
Understanding of network layers, protocols, flow control, and congestion control
Basic knowledge regarding data centers
Proficiency in at least one programming language such as GoLang, Python, or Java, with the ability to write code independently
Skill in building a cost profile for applications based on CPU, memory, IO, and network test results
Ability to profile CPU and memory consumption or raw dumps and familiarity with traces, thread dumps, and debug logs
Experience in creating performance test strategies, including the development of test cases
Proficiency in designing chaos test case scenarios and formulating test strategies by identifying potential failure points
This is a hybrid position. Hybrid employees can alternate time between both remote and office. Employees in hybrid roles are expected to work from the office 2-3 set days a week (determined by leadership/site), with a general guidepost of being in the office 50% or more of the time based on business needs.
If an employer mentions a salary or salary range on their job, we display it as an "Employer Estimate". If a job has no salary data, Rise displays an estimate if available.
Join our dynamic team at Open VisaNet as a Staff Software Engineer - Full Stack (Performance Engineering) and be part of the thrilling world of payment processing! In this role, you'll dive into hands-on performance and chaos engineering activities, creating innovative solutions for complex business challenges. If you're passionate about building applications that prioritize availability and resiliency, you're in the right place. In this hybrid position based in Foster City, you'll work closely with cross-functional teams, from development to project management, ensuring the delivery of high-quality applications. Your responsibilities will include developing performance models, conducting load tests, and fine-tuning distributed components. Collaborate with talented professionals to enhance application performance and engage in exciting chaos-resiliency evaluations. With a focus on continuous improvement, you will be responsible for analyzing metrics, identifying weaknesses, and helping shape the future of performance engineering at Open VisaNet. We are looking for someone with an in-depth understanding of application performance KPIs, a solid grasp of microservices architecture, and proficiency in programming languages like GoLang, Python, or Java. If you thrive in a challenging environment and are eager to contribute to performance tuning, scalability, and reliability, we want to hear from you!
We are looking for a Lead Engineer in AI & Software to drive transformative solutions at Boston Consulting Group.
Join Visionist Inc. as a Senior Software Engineer and contribute to critical software and analysis solutions for national security.
Join Link Solutions as a Web Software Developer to lead the design and development of web-based applications for the US Army.
Join Visa as a Senior Software Engineer and help innovate payment technologies for a truly global customer base.
Join Visa as an Automation engineer and contribute to innovative solutions within a dynamic corporate technology environment.
Join IQEQ as a Front-end Software Engineer to develop innovative RegTech solutions in an Agile environment.
Visa Inc. operates as a payments technology company worldwide. The company facilitates commerce through the transfer of value and information among consumers, merchants, financial institutions, businesses, strategic partners, and government entiti...
9499 jobsSubscribe to Rise newsletter