Senior Engineer - FICC Credit Technology
Job Description:At Bank of America, we are guided by a common purpose to help make financial lives better through the power of every connection. We do this by driving Responsible Growth and delivering for our clients, teammates, communities and shareholders every day.Being a Great Place to Work is core to how we drive Responsible Growth. This includes our commitment to being an inclusive workplace, attracting and developing exceptional talent, supporting our teammates’ physical, emotional, and financial wellness, recognizing and rewarding performance, and how we make an impact in the communities we serve.Bank of America is committed to an in-office culture with specific requirements for office-based attendance and which allows for an appropriate level of flexibility for our teammates and businesses based on role-specific considerations.At Bank of America, you can build a successful career with opportunities to learn, grow, and make an impact. Join us!Job Description:This job is responsible for defining and leading the engineering approach for complex features to deliver significant business outcomes. Key responsibilities of the job include delivering complex features and technology, enabling development efficiencies, providing technical thought leadership based on conducting multiple software implementations, and applying both depth and breadth in a number of technical competencies. Additionally, this job is accountable for end-to-end solution design and delivery.Job Profile Summary:FICC Electronic Trading supports eTrading businesses across Fixed Income, Currencies & Commodities. Credit eTrading sits within FICC eTrading and is focused on the electronic trading of corporate bonds and credit derivatives.The team is global, across Bromley, London, New York, Hong Kong, Tokyo, Chennai & Mumbai.This Lead Software Engineer role sits within the FICC Electronic Trading technology team, focused on Systematic Credit eTrading. Alongside supporting the continued existing Credit eTrading technology stack, you will lead the buildout of shared services for eTrading across FICC. You will have extensive experience overseeing the build of eTrading solutions – leading design discussions and build of eTrading software used in market connectivity, price distribution or RFQ engines, ideally with exposure across all three. You will have special interest in, or experience of, low latency systematic trading in Rates or Credit.Responsibilities:Ensures that the design and engineering approach for complex features are consistent with the larger portfolio solutionDefine the technology tool stack for the solution and evaluate and adapt new testing tool/framework/practices for team(s)Enables team(s)/applications with Continuous Integration/Continuous Development (CI/CD) capabilities and engages with other technical stakeholders pertaining to efficient functioning of CI-CD pipelineGuides and influences team(s) on design and best practices for high code performance –e.g. pairing, code reviewsProvides end-to-end delivery of complex features, including automation, for either a single team or multiple teams, at the program levelConducts research, design prototyping and other exploration activities such as evaluating new toolsets and components for release management, CI/CD, and featuresWorks with stakeholders to establish high-level solution needs and with architects for technical requirementsRequired QualificationsExperience as a Lead software engineer building eTrading solutions – software used in market connectivity, price distribution or RFQ engines.Must understand and have experience building out D2D, D2C and bilateral eTrading connectivity.Highly proficient in Java/Spring with expertise in developing FIX trading solutions.Experience working with trading desks, strategists & quants for L3 support on production trading systems as well as requirements gathering/solution design for new build.Experience supervising and growing eTrading engineering talentIn-depth knowledge of Credit or Rates eTrading workflows and market structureProficiency in debugging/profiling JDK based languages (Java/Scala/Kotlin/Clojure)Advanced work with JDK CI/CD and build toolchains including Maven, Gradle, SBT, JenkinsExperience with modern RPC microservices, specifically GraphQL and gRPCProficiency in developing for Unix/Linux based environments including shell basics as well as process and network diagnostics.Exposure to monitoring, metrics and tracing tooling - ELK stack, Splunk, Prometheus, Grafana, Graphite, OpenTSDB, OpenTrace, JaegerExposure to message-oriented architecture - ZeroMQ, JMS, AMPS, RabbitMQ, Kafka, Google pub/subExposure to process/container orchestration technologies - Mesos, Kubernetes, OpenShift, dockerHigh proficiency in data architecture in both SQL and NoSQL data stores such as MongoDB, Cassandra, CouchDB, HBaseExperience with reactive streams implementations and observables - ReactiveX (RXJava, RXJS, etc), Akka Streams, Monix, Spring ReactorDesired QualificationsUnderstanding of machine architecture and natively compiled languages such as C++ and RustExperience with CQRS architecture.Experience with Scala functional and/or concurrency libraries such as ZIO, C Skills:AutomationInfluenceResult OrientationStakeholder ManagementTechnical Strategy DevelopmentApplication DevelopmentArchitectureBusiness AcumenRisk ManagementSolution DesignAgile PracticesAnalytical ThinkingCollaborationData ManagementSolution Delivery ProcessMinimum Education Requirements: Bachelor Degree or Equivalent Professional ExperienceShift:1st shift (United States of America)Hours Per Week: 40